PrincipalExtractor 和 AuthoritiesExtractor 没有被调用

nik*_*ana 5 spring-boot spring-security-oauth2

我有一个简单的 OAuth2 应用程序。我首先创建了一个扩展 WebSecurityConfigurerAdapter 的 SecurityConfig,并用 @EnableOAuth2Sso 进行了注释。我还在控制器中创建了一个 API 来测试身份验证是否有效。Principal 被注入控制器并给出正确的名称。

我现在试图通过实现 AuthoritiesExtractor 并将其创建为 bean 来向主体添加一些权限。我也对 PrincipalExtractor 做了同样的事情来检查它是否工作。在从浏览器发出任何请求时,它们都不会被调用。

编辑:这实际上只是使用 OIDC 进行身份验证,因此我的客户端和资源在同一个应用程序上。

// 这是我的安全配置类。

@Configuration
@EnableOAuth2Sso
public class SecurityConfig extends WebSecurityConfigurerAdapter {

@Override
public void configure(HttpSecurity http) throws Exception {
     http
     .antMatcher("/**")
     .authorizeRequests()
       .antMatchers("/login**","/error**")
       .permitAll()
     .anyRequest()
       .authenticated();
}

@Bean
public PrincipalExtractor principalExtractor() {
    return map -> {
        System.out.println("Principal extracted.");
        User user = new User();
        user.setUsername((String)map.get("username"));
        return user;
    };
}

@Bean
public AuthoritiesExtractor authoritiesExtractor() {
    return new PrismAuthoritiesExtractor();
}
}
Run Code Online (Sandbox Code Playgroud)

// 这是我单独定义的 AuthoritiesExtractor 类,只是为了检查这样做是否有效。

public class PrismAuthoritiesExtractor implements AuthoritiesExtractor {

@Override
public List<GrantedAuthority> extractAuthorities(Map<String, Object> map) {
    return AuthorityUtils.commaSeparatedStringToAuthorityList("AUTH1,AUTH2");
}
}
Run Code Online (Sandbox Code Playgroud)

kon*_*nqi 5

我为此挣扎了一段时间。AuthoritiesExtractor没有调用我的bean的原因是因为较新版本的 Spring 不使用 spring oauth2 autoconfigure 并且AuthoritiesExtractor是覆盖角色映射的 oauth2 autoconfigure 方式。

在当前版本的 spring-security 中,您可以将基于委托的策略与 OAuth2UserService 一起使用。文档中的示例应该足以让您继续前进。我正在使用 Kotlin,所以我的示例可能不适合你。

还有应该更接近该方法的GrantedAuthoritiesMapperAuthoritiesExtractor