Spring security + JWT 403 запрещенная ошибка - PullRequest
1 голос
/ 18 апреля 2020

Итак, я пытаюсь защитить API с помощью токенов SpringSecurity и JWT. Я могу получить токен, но каждый раз, когда я пытаюсь получить доступ к защищенной конечной точке, используя токен, я получаю 403 Запрещено. У меня есть БД, содержащая роли и пользователей. Вот моя весенняя конфигурация безопасности:

 httpSecurity.csrf().disable().cors().disable()
            // dont authenticate this particular request
            .authorizeRequests().antMatchers("/authenticate", "/register").permitAll()
            .antMatchers("/admin/**").hasRole("ADMIN")
            .antMatchers("/system/**").hasRole("ADMIN")
            //.antMatchers("/system").permitAll()
            // all other requests need to be authenticated
                    //.anyRequest().permitAll()
            .and().
            // make sure we use stateless session; session won't be used to
            // store user's state.
                    exceptionHandling().authenticationEntryPoint(jwtAuthenticationEntryPoint).and().sessionManagement()
            .sessionCreationPolicy(SessionCreationPolicy.STATELESS);

    // Add a filter to validate the tokens with every request
    httpSecurity.addFilterBefore(jwtRequestFilter, UsernamePasswordAuthenticationFilter.class);

Я попытался отладить, и токен может быть декодирован, пользовательская информация может быть доступна, и пользовательский объект, содержащий роли, может быть получен. Вот почему я действительно не знаю, что происходит.

Debugging vars :

А вот мой метод фильтрации из класса RequestFilter:

String username = null;
String jwtToken = null;
// JWT Token is in the form "Bearer token". Remove Bearer word and get
// only the Token
if (requestTokenHeader != null && requestTokenHeader.startsWith("Bearer ")) {
    jwtToken = requestTokenHeader.substring(7);
    try {
        username = jwtTokenUtil.getUsernameFromToken(jwtToken);
    } catch (IllegalArgumentException e) {
        System.out.println("Unable to get JWT Token");
    }
} else {
    logger.warn("JWT Token does not begin with Bearer String");
}       // Once we get the token validate it.
if (username != null && SecurityContextHolder.getContext().getAuthentication() == null) {           UserDetails userDetails = this.jwtUserDetailsService.loadUserByUsername(username);          // if token is valid configure Spring Security to manually set
    // authentication
    if (jwtTokenUtil.validateToken(jwtToken, userDetails)) {                UsernamePasswordAuthenticationToken usernamePasswordAuthenticationToken = new UsernamePasswordAuthenticationToken(
            userDetails, null, userDetails.getAuthorities());
        usernamePasswordAuthenticationToken
                .setDetails(new WebAuthenticationDetailsSource().buildDetails(request));
        // After setting the Authentication in the context, we specify
        // that the current user is authenticated. So it passes the
        // Spring Security Configurations successfully.
        SecurityContextHolder.getContext().setAuthentication(usernamePasswordAuthenticationToken);
    }
}
chain.doFilter(request, response);

Извините за это длинное сообщение:)

1 Ответ

1 голос
/ 18 апреля 2020

Вам необходимо добавить префикс SimpleGrantedAuthority к ROLE_.
Добавить что-то подобное в ваш UserDetailsService.

String ROLE_PREFIX = "ROLE_";
authorities.add(new SimpleGrantedAuthority(ROLE_PREFIX + user.getRole()));
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...