1000字范文,内容丰富有趣,学习的好帮手!
1000字范文 > SpringBoot+拦截器+自定义异常+自定义注解+全局异常处理简单实现接口权限管理...

SpringBoot+拦截器+自定义异常+自定义注解+全局异常处理简单实现接口权限管理...

时间:2022-08-09 15:40:10

相关推荐

SpringBoot+拦截器+自定义异常+自定义注解+全局异常处理简单实现接口权限管理...

点击关注公众号,实用技术文章及时了解

来源:/weixin_44102992/article/

details/107335702

前言

提到权限管理这块肯定很多人第一想到的就是Springboot Security或者是Shiro安全框架,但本文介绍的并不是这两种,不是因为他们不好用,实在是自己太懒了,我觉得一个拦截器加上其他的一些处理就能满足项目的需求,我又何必去多用一个框架呢,这篇文章也不是去对比谁好谁坏,各位自行抉择。

我将权限管理分为三块:

资源权限:将url当做资源,可以给每个账号动态划分Url权限,访问不同的URl;

操作权限:将所有URL分为增、删、改、查4种操作权限,给用户分配对应的操作权限,如某个用户只有查操作权限那么他就无法做其他的操作;

角色权限:系统有多个角色,每个角色的权限都不同,如一个管理后台有着账号管理模块、商品模块等,为超级管理员的角色就可以看到所有模块并操作,而为售后的角色就只能看到商品模块,即使他知道账号管理模块下的URL也无权限操作。然后为用户设置角色就有对应的权限;

资源权限

1.静态资源准备

这里方便演示就不直接操作数据库了,对应的权限建表关系也很简单,这里直接建立静态的用户对应的URL关系。

publicclassConstant{/***权限管理*/publicstaticMap<Integer,String[]>permission=newHashMap<>();static{String[]frist={"/url1","/url2","/url3","/url4","/url5","/url6","/url7"};//用户1所拥有的URL权限String[]second={"/url1","/url2","/url3","/url4","/url5"};//用户2所拥有的URL权限String[]third={"/url1","/url2","/url3"};//用户3所拥有的URL权限permission.put(1,frist);permission.put(2,second);permission.put(3,third);}}

2.自定义一个异常,便于拦截抛出

publicclassAPIExceptionextendsRuntimeException{privatestaticfinallongserialVersionUID=1L;privateStringmsg;publicAPIException(Stringmsg){super(msg);this.msg=msg;}}

3.全局异常处理

便于异常后返回统一规范的结果,正常应该是正常返回自定义Vo,但这里目标是为了演示结果,再加上各位应该都有自己的Vo类,所以这里就不用了

@RestControllerAdvicepublicclassWebExceptionControl{@ExceptionHandler(APIException.class)publicStringAPIExceptionHandler(APIExceptione){returne.getMessage();}}

4.controller层

很简单创建对应的URL就好

5.拦截器创建

一般是要先验证token,后根据token取到用户对应信息,这里没有登录所以就直接在token里传对应用户的key值了

/***权限管理URL拦截器*/publicclassURLInterceptorimplementsHandlerInterceptor{//预处理回调方法,在接口调用之前使用true代表放行false代表不放行@OverridepublicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler){HttpServletRequesthttpServletRequest=(HttpServletRequest)request;Stringtoken=httpServletRequest.getHeader("token");StringrequestURL=httpServletRequest.getRequestURI();//1.根据token判断用户是否登录if(token==null){//正常情况下这里还需判断与redis中的token是否匹配//如果没有token或者token不匹配,直接抛出异常提示未登录thrownewAPIException("当前用户未登录");}//2.登录成功后根据用户token中的信息获取到用户对应的URL权限集合String[]strings=Constant.permission.get(Integer.valueOf(token));booleanhasPermission=false;//3.再根据用户对应的URL集合去与当前请求的URL对比有匹配的则放行反之则抛出异常for(inti=0;i<strings.length;i++){if(strings[i].equals(requestURL)){hasPermission=true;break;}}if(hasPermission){returntrue;}else{thrownewAPIException("当前用户没有访问路径"+requestURL+"的权限");}}}

6.将拦截器注入应用

@ConfigurationpublicclassWebMvcConfgimplementsWebMvcConfigurer{@OverridepublicvoidaddInterceptors(InterceptorRegistryregistry){//权限拦截器registry.addInterceptor(urlInterceptor()).addPathPatterns("/**");}@BeanpublicURLInterceptorurlInterceptor(){returnnewURLInterceptor();}}

7.验证查看结果

分别在token中传入用户1-3的key,访问不同url就可以看到效果,如下

操作权限

1.和上面一样使用静态资源

publicclassConstant{/***权限管理*/publicstaticMap<Integer,String[]>permission=newHashMap<>();static{String[]frist={"insert","delete","select","update"};//用户1所拥有的操作权限String[]second={"insert","select","update"};//用户2所拥有的URL权限String[]third={"select"};//用户3所拥有的URL权限permission.put(1,frist);permission.put(2,second);permission.put(3,third);}}

2.自定义注解

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)public@interfaceUrlAnnotation{/***操作类型(type):添加,删除,修改,插入**/Stringtype();}

3.controller层

打上自定义的注解,代表对应方法是什么操作

4.修改一下之前的拦截器

添加对注解上面的操作类型的获取,并用type类型去对比判断

5.验证结果

其他都不变

角色权限

这里其实和上面的操作大同小异,我这里简单演示一下,以两个模块为例

1.静态对应关系

publicclassConstant{/***权限管理*/publicstaticMap<Integer,String[]>permission=newHashMap<>();static{String[]frist={"test","test1"};//用户1所拥有的模块权限这里的test是模块URL入口例如:test模块下所有URL都是/test/**String[]second={"test"};//用户2所拥有的模块权限permission.put(1,frist);//这里的1其实是用户对应ID为1的角色permission.put(2,second);//这个2同理}

2.修改controller

模拟两个模块

3.修改一下拦截器

4.结果测试

总结

其实用自定义的拦截器去做权限,不管是什么类型其实都大同小异,根据需求灵活的去处理才是最重要的,上面的静态权限变通一下,建立角色表、用户表、路径表以及对应关系,就很容易做出URL的动态权限配置了,灵活运用自定义注解搭配可以做到更细致。

推荐

主流Java进阶技术(学习资料分享)

Java面试题宝典

加入Spring技术开发社区

PS:因为公众号平台更改了推送规则,如果不想错过内容,记得读完点一下“在看”,加个“星标”,这样每次新文章推送才会第一时间出现在你的订阅列表里。点“在看”支持我们吧!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。