我找了很长时间的答案,但没有找到任何有成效的东西
在我的休息服务中,我将一些功能保留在:/account/{id}/download,我希望在SecurityConfig java文件中设置访问权限ROLE,以便只有ROLE_TOKENSAVED用户才能访问此URL
当{id}可更改时,模式应该是什么样子?
我尝试了一些regexp模式,但没有一个像我想要的那样工作,下面是我的一些尝试:
1. antMatchers("account/**/download").access(somerolehere)
2. antMatchers("account/\\d/download").access(somerolehere)
3. antMatchers("account/[\\d]/download").access(somerolehere)
提前感谢你的回答:)
编辑:
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.antMatchers("/admin**").access("hasRole('ROLE_ADMIN')")
.antMatchers("/account*//**").access("hasRole('ROLE_USER') or hasRole('ROLE_ADMIN')")
.antMatchers("/account/\\d+/download").access("hasRole('ROLE_TOKENSAVED')")
.antMatchers("/user**").permitAll()
//othercode...
}
3条答案
按热度按时间fnx2tebb1#
这对我很有效:
请注意表示ID的路径变量周围的花括号。
rta7y2nd2#
虽然Bohuslav的建议有效,但它并不完整。根据AntPathMarcher的文档:http://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/util/AntPathMatcher.html
您需要使用regex指定路径变量:
第一个月
如果不这样做,可能会暴露其他路由。例如:
和UserController上的这些方法:
由于您没有指定路径变量
userId
,用户将能够在没有管理员权限的情况下在“/users/roles”上执行GET请求。此外,即使需要管理员权限,“/users/test”等将来路径也将暴露。如果路径变量名称是“accountId”
mitkmikd3#
我想我也遇到过类似的问题,在大多数情况下,类似antMatchers(“/items/{\d+})的东西不起作用,但如果我读到antMatchers(“/items/{d+})(没有//),它就起作用了。