401 -> authentication issue
403 -> forbidden , authorization issue
@Configuration
public class ResourceServerConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http.oauth2ResourceServer(
c -> c.jwt(
j -> j.decoder(decoder())
.jwtAuthenticationConverter(converter())
)
);
http.authorizeRequests()
.mvcMatchers("/demo/**").hasAuthority("read");
}
@Bean
public JwtDecoder decoder() {
String key = "ymLTU8rq83j4fmJZj60wh4OrMNuntIj4fmJ";
SecretKey secretKey = new SecretKeySpec(key.getBytes(),0 ,key.getBytes().length, "AES");
return NimbusJwtDecoder.withSecretKey(secretKey)
.build();
}
@Bean
public JwtAuthenticationConverter converter() {
var conv = new JwtAuthenticationConverter();
conv.setJwtGrantedAuthoritiesConverter(jwt -> {
JSONArray a = (JSONArray) jwt.getClaims().get("authorities");
return a.stream()
.map(String::valueOf)
.map(SimpleGrantedAuthority::new)
.collect(Collectors.toList());
});
return conv;
}
}
need to specify converter or resource server will not be able to extract GrantedAuthorites
'WEB > Security' 카테고리의 다른 글
Lesson 29 - Using permissions (0) | 2022.05.20 |
---|---|
Lesson 27 - Method authorization configurations (0) | 2022.05.16 |
Lesson 24,25 - Authorities, Roles and Matcher methods (mvc,ant) (0) | 2022.05.14 |
Lesson 23 - Configuring endpoint authorization (0) | 2022.05.13 |
Lesson 20 - Using Keycloak as an authorization server (0) | 2022.05.11 |