电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

SpringBoot如何通過自定義注解實現(xiàn)權(quán)限檢查詳解

瀏覽:120日期:2023-08-08 13:02:44

前言

最近開發(fā)了一個接口,完成后準備自測時,卻被攔截器攔截了,提示:(AUTH-NO)未能獲得有效的請求參數(shù)!怎么會這樣呢?

于是我全局搜了這個提示語,結(jié)果發(fā)現(xiàn)它被出現(xiàn)在一個Aspect類當中了,并且把一個 @interface 作為了一個切點,原來這里利用了Spring AOP面向切面的方式進行權(quán)限控制。

SpringBoot通過自定義注解實現(xiàn)日志打印可參考:SpringBoot通過自定義注解實現(xiàn)日志打印

正文

Spring AOP

Spring AOP 即面向切面,是對OOP面向?qū)ο蟮囊环N延伸。

AOP機制可以讓開發(fā)者把業(yè)務流程中的通用功能抽取出來,單獨編寫功能代碼。在業(yè)務流程執(zhí)行過程中,Spring框架會根據(jù)業(yè)務流程要求,自動把獨立編寫的功能代碼切入到流程的合適位置。

我們通過AOP機制可以實現(xiàn):Authentication 權(quán)限檢查、Caching 緩存、Context passing 內(nèi)容傳遞、Error handling 錯誤處理、日志打印等功能,這里我們講一下怎么用Spring AOP來實現(xiàn)權(quán)限檢查。

SpringBoot 通過自定義注解實現(xiàn)權(quán)限檢查

Maven依賴

<!--lombok--><dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.2</version> <optional>true</optional></dependency><!--Spring AOP--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId></dependency>

MyPermissionTag.class自定義注解

@Retention: 用來修飾注解,是注解的注解,稱為元注解。 @Target:用來說明對象的作用范圍

/** * 用戶請求權(quán)限校驗 */@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.METHOD)public @interface MyPermissionTag { String value() default ''; String name() default '';}

這里特別講一下@Retention,按生命周期來劃分可分為3類:

RetentionPolicy.SOURCE:注解只保留在源文件,當Java文件編譯成class文件的時候,注解被遺棄(運行時去動態(tài)獲取注解信息); RetentionPolicy.CLASS:注解被保留到class文件,但jvm加載class文件時候被遺棄,這是默認的生命周期(在編譯時進行一些預處理操作); RetentionPolicy.RUNTIME:注解不僅被保存到class文件中,jvm加載class文件之后,仍然存在(做一些檢查性的操作);

這3個生命周期分別對應于:Java源文件(.java文件) —> .class文件 —> 內(nèi)存中的字節(jié)碼。

AuthInterceptor 權(quán)限檢查的切面

這里簡單介紹一下,切面的執(zhí)行方法和其執(zhí)行順序:

@Around 通知方法將目標方法封裝起來 @Before 通知方法會在目標方法調(diào)用之前執(zhí)行 @After 通知方法會在目標方法返回或者異常后執(zhí)行 @AfterReturning 通知方法會在目標方法返回時執(zhí)行 @Afterthrowing 通知方法會在目標方法拋出異常時執(zhí)行

這里以一個返回正常的情況為例:(異常替換最后一步即可)

SpringBoot如何通過自定義注解實現(xiàn)權(quán)限檢查詳解

AuthInterceptor.class

注意要在啟動類掃描這個class,并且添加 @EnableAspectJAutoProxy(proxyTargetClass = true)

@Slf4j@Aspect@Componentpublic class AuthInterceptor { /** * 參數(shù)處理 * * @param point */ @Before('@annotation(com.luo.common.tag.MyPermissionTag)') public void beforeProReq(JoinPoint point) { log.info('前置攔截-開始'); Request req = getOperationRequest(point.getArgs()); if (req != null) { //解密帳號 log.info('前置攔截-開始解密ACCOUNT:{}', req.getAccount()); log.info('前置攔截-結(jié)束解密ACCOUNT:{}', req.getAccount()); } log.info('前置攔截-結(jié)束'); } @Around('@annotation(com.luo.common.tag.MyPermissionTag)') public Object authCheck(ProceedingJoinPoint pjp) throws Throwable { log.info('權(quán)限攔截-開始'); //請求方法 ReqMethod reqMethod = getPermissionTag(pjp); MyPermissionTag myPermissionTag =reqMethod.perTag; log.info(myPermissionTag.value()); //獲取配置的值 log.info('權(quán)限攔截-開始-攔截到方法:{}', reqMethod.getMethodName()); if('true'.equals(myPermissionTag.value().toString())){ //錯誤返回 Response notGoRes = new Response(); Request req = getOperationRequest(pjp.getArgs()); // 校驗請求對象 if (req == null) { notGoRes.setErrorMsg('(AUTH)未能獲得有效的請求參數(shù)!'); log.info('(AUTH-NO)未能獲得有效的請求參數(shù)!'); return notGoRes; }else {//可以在這里根據(jù)請求參數(shù)對請求做進一步校驗 log.info('完成請求校驗:'+req); } }else { log.info('未開啟權(quán)限校驗'); } return pjp.proceed(); } /** * 獲取 request 接口中的請求參數(shù) * @param args * @return */ private Request getOperationRequest(Object[] args) { if (args == null || args.length <= 0) { log.error('AUTH權(quán)限驗證:攔截方法的請求參數(shù)為空!'); return null; } Object obj = args[0]; if (obj instanceof Request) { log.info('AUTH權(quán)限驗證:請求對象為正確的OperationRequest對象'); return (Request) obj; } return null; } /** * 獲取攔截的資源標簽 * 這里可以獲取方法名+注解信息(包括 key+value 等) * @param pjp * @return * @throws SecurityException * @throws NoSuchMethodException */ private ReqMethod getPermissionTag(ProceedingJoinPoint pjp) throws NoSuchMethodException, SecurityException { Signature signature = pjp.getSignature(); MethodSignature methodSignature = (MethodSignature) signature; Method targetMethod = methodSignature.getMethod(); Method realMethod = pjp.getTarget().getClass().getDeclaredMethod(signature.getName(), targetMethod.getParameterTypes()); MyPermissionTag permissionTag = realMethod.getAnnotation(MyPermissionTag.class); return new ReqMethod(permissionTag, realMethod.getName()); } @Setter @Getter class ReqMethod { private MyPermissionTag perTag; private String methodName; public ReqMethod(MyPermissionTag perTag, String methodName) { this.perTag = perTag; this.methodName = methodName; } }}

驗證

測試接口

@PostMapping('/helloluo')@MyPermissionTag(value = 'true')public String helloluo(UserPojoReq userPojoReq){ return 'Hello World';}

發(fā)送請求

SpringBoot如何通過自定義注解實現(xiàn)權(quán)限檢查詳解

驗證

SpringBoot如何通過自定義注解實現(xiàn)權(quán)限檢查詳解

總結(jié)

到此這篇關(guān)于SpringBoot如何通過自定義注解實現(xiàn)權(quán)限檢查的文章就介紹到這了,更多相關(guān)SpringBoot自定義注解實現(xiàn)權(quán)限檢查內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 变频器维修公司_plc维修_伺服驱动器维修_工控机维修 - 夫唯科技 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 成都中天自动化控制技术有限公司 | 海尔生物医疗四川代理商,海尔低温冰箱四川销售-成都壹科医疗器械有限公司 | 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | 学生作文网_中小学生作文大全与写作指导 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 耐高温风管_耐高温软管_食品级软管_吸尘管_钢丝软管_卫生级软管_塑料波纹管-东莞市鑫翔宇软管有限公司 | 储能预警-储能消防系统-电池舱自动灭火装置-四川千页科技股份有限公司官网 | 陕西安闸机-伸缩门-车牌识别-广告道闸——捷申达门业科技 | 定量包装机,颗粒定量包装机,粉剂定量包装机,背封颗粒包装机,定量灌装机-上海铸衡电子科技有限公司 | 民用音响-拉杆音响-家用音响-ktv专用音响-万昌科技 | 不锈钢搅拌罐_高速搅拌罐厂家-无锡市凡格德化工装备科技有限公司 | 快速门厂家批发_PVC快速卷帘门_高速门_高速卷帘门-广州万盛门业 快干水泥|桥梁伸缩缝止水胶|伸缩缝装置生产厂家-广东广航交通科技有限公司 | 室内室外厚型|超薄型|非膨胀型钢结构防火涂料_隧道专用防火涂料厂家|电话|价格|批发|施工 | 超高频感应加热设备_高频感应电源厂家_CCD视觉检测设备_振动盘视觉检测设备_深圳雨滴科技-深圳市雨滴科技有限公司 | 字典-新华字典-在线字典查字-字典趣| 北京网站建设首页,做网站选【优站网】,专注北京网站建设,北京网站推广,天津网站建设,天津网站推广,小程序,手机APP的开发。 | ★济南领跃标识制作公司★济南标识制作,标牌制作,山东标识制作,济南标牌厂 | 网带通过式抛丸机,,网带式打砂机,吊钩式,抛丸机,中山抛丸机生产厂家,江门抛丸机,佛山吊钩式,东莞抛丸机,中山市泰达自动化设备有限公司 | 长沙发电机-湖南发电机-柴油发电机供应厂家-长沙明邦智能科技 | 台式低速离心机-脱泡离心机-菌种摇床-常州市万丰仪器制造有限公司 | 稳尚教育加盟-打造高考志愿填报平台_新高考志愿填报加盟_学业生涯规划加盟 | Maneurop/美优乐压缩机,活塞压缩机,型号规格,技术参数,尺寸图片,价格经销商 | 食品无尘净化车间,食品罐装净化车间,净化车间配套风淋室-青岛旭恒洁净技术有限公司 | 东莞喷砂机-喷砂机-喷砂机配件-喷砂器材-喷砂加工-东莞市协帆喷砂机械设备有限公司 | 护栏打桩机-打桩机厂家-恒新重工| 萃取箱-萃取槽-PVC萃取箱厂家-混合澄清槽- 杭州南方化工设备 | 桌上式超净工作台-水平送风超净工作台-上海康路仪器设备有限公司 | 懂研帝_专业SCI论文润色机构_SCI投稿发表服务公司 | 郑州外墙清洗_郑州玻璃幕墙清洗_郑州开荒保洁-河南三恒清洗服务有限公司 | 不锈钢轴流风机,不锈钢电机-许昌光维防爆电机有限公司(原许昌光维特种电机技术有限公司) | 档案密集柜_手动密集柜_智能密集柜_内蒙古档案密集柜-盛隆柜业内蒙古密集柜直销中心 | 空调风机,低噪声离心式通风机,不锈钢防爆风机,前倾皮带传动风机,后倾空调风机-山东捷风风机有限公司 | 粉碎机_塑料粉碎机_塑料破碎机厂家-星标机械 | 【化妆品备案】进口化妆品备案流程-深圳美尚美化妆品有限公司 | 德国UST优斯特氢气检漏仪-德国舒赐乙烷检测仪-北京泽钏 | 辊道窑炉,辊道窑炉厂家-山东艾希尔 | 生产加气砖设备厂家很多,杜甫机械加气砖设备价格公道 | 千淘酒店差旅平台-中国第一家针对TMC行业的酒店资源供应平台 | 成都办公室装修-办公室设计-写字楼装修设计-厂房装修-四川和信建筑装饰工程有限公司 | 免费个人pos机申请办理-移动pos机刷卡-聚合收款码办理 |