【发布时间】:2014-05-09 10:10:33
【问题描述】:
我正在使用 Spring Security 3.2.3.RELEASE
这是我的 WebSecurityConfigurerAdapter 的代码
@Configuration
@EnableWebSecurity
public class WebSecurityContext extends WebSecurityConfigurerAdapter {
private static final Logger log = LogManager.getLogger(WebSecurityContext.class);
@Autowired
private AuthenticationProvider authenticationProvider;
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
log.info("Setting AuthenticationManagerBuilder");
auth.authenticationProvider(authenticationProvider);
}
@Override
protected void configure(HttpSecurity http) throws Exception {
log.info("Configuring HttpSecurity");
http
.authorizeRequests()
.antMatchers("/admin/**").hasRole("ADMIN")
.antMatchers("/**").hasRole("USER")
.anyRequest().authenticated()
.and()
.httpBasic();
}
}
结果是:HTTP 状态 403 - 访问被拒绝
但如果我评论这一行:
//.antMatchers("/**").hasRole("USER")
一切正常。这意味着(我猜)我的角色或 HttpSecurity 有问题。
于是我开始调试。我仔细检查了我的 UserDetails 是否有两个 GrantedAuthorities,名称分别为:ADMIN、USER。
那么有什么想法可能导致问题吗?
【问题讨论】:
标签: java spring configuration spring-security