正确配置Spring Security OAuth2

我正在尝试使用spring-security-oauth2和jwt配置授权服务器。

我的主要:

@SpringBootApplication

@EnableResourceServer

public class Application {

public static void main(String[] args) {

SpringApplication.run(Application.class, args);

}

}

我的安全性配置:

@Configuration

@EnableGlobalMethodSecurity(prePostEnabled = true)

public class SecurityConfig extends WebSecurityConfigurerAdapter {

@Override

@Bean

public AuthenticationManager authenticationManagerBean() throws Exception {

return super.authenticationManagerBean();

}

@Override

protected void configure(HttpSecurity http) throws Exception {

}

@Override

protected void configure(AuthenticationManagerBuilder auth) throws Exception {

auth

.inMemoryAuthentication()

.withUser("john").password("123").roles("USER").authorities("FOO_READ");

}

}

我的身份验证服务器配置:

@Configuration

@EnableAuthorizationServer

public class AuthServerConfig extends AuthorizationServerConfigurerAdapter {

@Autowired

@Qualifier("authenticationManagerBean")

private AuthenticationManager authenticationManager;

@Override

public void configure(ClientDetailsServiceConfigurer clients) throws Exception {

clients.inMemory()

.withClient("gateway")

.secret("secret")

.authorizedGrantTypes("refresh_token", "password")

.scopes("GATEWAY")

.autoApprove(true) ;

}

@Override

public void configure(AuthorizationServerEndpointsConfigurer endpoints) throws Exception {

endpoints.tokenEnhancer(jwtTokenEnhancer()).authenticationManager(authenticationManager);

}

}

和一个访问当前用户的Web服务:

@RestController

public class UserController {

@GetMapping("/users/me")

public Principal user(Principal principal) {

return principal;

}

}

现在,如果我发出这样的帖子请求:

gateway:secret@localhost:10101/oauth/token

grant_type : password

username : john

password : 123

我有这样的回应:

{

"access_token": "...access token...",

"token_type": "bearer",

"refresh_token": "...refresh token...",

"expires_in": 43199,

"scope": "GATEWAY",

"jti": "...jti..."

}

如果我使用访问令牌来调用我的用户WS:

GET localhost:10101/users/me

Authorization : Bearer ...access token...

我得到一个空响应。

但是,如果我在“安全性”配置中输入以下内容:

    @Override

protected void configure(HttpSecurity http) throws Exception {

http.requestMatchers().antMatchers("/wtf");

}

然后,我获得适当的响应。

有人可以解释一下这是怎么回事吗?为什么没有此附加行就无法识别我的用户?

谢谢。

回答:

实际上,这是Spring安全性的问题。解决方案在此线程中:

https://github.com/spring-projects/spring-security-

oauth/issues/980

应该添加此注释,以便正确调用Adapter:

@Configuration 

@Order(SecurityProperties.ACCESS_OVERRIDE_ORDER)

class WebSecurityConfiguration extends WebSecurityConfigurerAdapter {

// ...

}

另一个解决方案是实现ResourceServerConfigurerAdapter而不是WebSecurityConfigurerAdapter。

以上是 正确配置Spring Security OAuth2 的全部内容, 来源链接: utcz.com/qa/425179.html

回到顶部