springboot+shiro 怎么拦截 restful 风格的URL,判断其是否有权限
/**
* DESC:
* 权限校验过滤器
*/
public class PermissionFilter extends AccessControlFilter {
@Override
protected boolean isAccessAllowed(ServletRequest request,
ServletResponse response, Object mappedValue) throws Exception {
HttpServletRequest httpRequest = ((HttpServletRequest)request);
/**
* 这里需要处理一下请求的URL路径,把它转成shiro addStringPermission 存储的URL格式,如:/user/email
* 所以这里替换了一下,使用根目录开始的URI
*/
String uri = httpRequest.getRequestURI();//获取URI
System.out.println("当前请求的URL:"+uri);
String basePath = httpRequest.getContextPath();//获取basePath
if(null != uri && uri.startsWith(basePath)){
uri = uri.replaceFirst(basePath, "");
}
if(subject.isPermitted(uri)){
System.out.println("有权限");
return Boolean.TRUE;
}
上面的URL拦截并判断权限,如果是传统的URL的话可以很容易的判断是否有权限。但是如果时restful 风格的url的话怎么拦截判断是否有权限呢?因为数据库权限表保存的URL是没有带参数的比如:/user 但是restful风格API请求时会携带参数 : /user/1
所以使用:
if(subject.isPermitted(uri)){
System.out.println("有权限");
return Boolean.TRUE;
}
根本不能判断,
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
通过new AntPathMatcher()来判断,对于/a/b/{id}形式的api支持通配符的匹配,用/a/b/ 即可以,注意要用两个
可以通过
AntPathMatcher
来判断 URI 是否匹配,只是需要将数据库中存储的 URI 改为为 Ant 风格的 URI,如:/users/**