色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Spring AOP實現權限檢查的功能

瀏覽:86日期:2023-08-18 11:43:40

前言

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

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

正文

Spring AOP 即面向切面,是對OOP面向對象的一種延伸。AOP機制可以讓開發者把業務流程中的通用功能抽取出來,單獨編寫功能代碼。在業務流程執行過程中,Spring框架會根據業務流程要求,自動把獨立編寫的功能代碼切入到流程的合適位置。

我們通過AOP機制可以實現:Authentication 權限檢查、Caching 緩存、Context passing 內容傳遞、Error handling 錯誤處理等功能,這里我們講一下怎么用Spring AOP來實現權限檢查。

Spring AOP實現權限檢查

引入依賴

<!--lombok--><dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.2</version> <optional>true</optional></dependency><!--Spring AOP--><dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId></dependency><dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId></dependency><dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.9.2</version></dependency><dependency> <groupId>aopalliance</groupId> <artifactId>aopalliance</artifactId> <version>1.0</version></dependency>

MyPermissionTag.class自定義注解

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

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

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

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

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

AuthInterceptor 權限檢查的切面

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

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

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

Spring AOP實現權限檢查的功能

AuthInterceptor.class

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

@Slf4j@Aspect@Componentpublic class AuthInterceptor { /** * 參數處理 * * @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('前置攔截-結束解密ACCOUNT:{}', req.getAccount()); } log.info('前置攔截-結束'); } @Around('@annotation(com.luo.common.tag.MyPermissionTag)') public Object authCheck(ProceedingJoinPoint pjp) throws Throwable { log.info('權限攔截-開始'); //請求方法 ReqMethod reqMethod = getPermissionTag(pjp); MyPermissionTag myPermissionTag =reqMethod.perTag; log.info(myPermissionTag.value()); //獲取配置的值 log.info('權限攔截-開始-攔截到方法:{}', reqMethod.getMethodName()); if('true'.equals(myPermissionTag.value().toString())){ //錯誤返回 Response notGoRes = new Response(); Request req = getOperationRequest(pjp.getArgs()); // 校驗請求對象 if (req == null) {notGoRes.setErrorMsg('(AUTH)未能獲得有效的請求參數!');log.info('(AUTH-NO)未能獲得有效的請求參數!');return notGoRes; }else {//可以在這里根據請求參數對請求做進一步校驗log.info('完成請求校驗:'+req); } }else { log.info('未開啟權限校驗'); } return pjp.proceed(); } /** * 獲取 request 接口中的請求參數 * @param args * @return */ private Request getOperationRequest(Object[] args) { if (args == null || args.length <= 0) { log.error('AUTH權限驗證:攔截方法的請求參數為空!'); return null; } Object obj = args[0]; if (obj instanceof Request) { log.info('AUTH權限驗證:請求對象為正確的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';}

發送請求

Spring AOP實現權限檢查的功能

驗證

Spring AOP實現權限檢查的功能

到此這篇關于Spring AOP實現權限檢查的功能的文章就介紹到這了,更多相關Spring AOP 權限檢查內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 国产一区二区三区免费看 | 全部毛片 | 玖玖视频精品 | 亚洲综合第一欧美日韩中文 | ffyybb免费福利视频 | 亚洲免费网站在线观看 | 91在线 | 亚洲| 免费一级毛片在播放视频 | 大尺度福利视频奶水在线 | 六月成人网 | 国产精品成aⅴ人片在线观看 | 国产一久久香蕉国产线看观看 | 亚洲悠悠色综合中文字幕 | 色吊丝avav色吊丝 | 亚洲欧美国产中文 | 日本欧美久久久久免费播放网 | 欧美成人精品大片免费流量 | 最新欧美精品一区二区三区不卡 | 欧美 自拍 | 欧美性生交大片免费看 | 亚洲加勒比久久88色综合1 | 国产精自产拍久久久久久 | 草草久 | 国产午夜精品免费一二区 | 国内在线精品 | 亚洲经典在线 | 一级视频免费观看 | 狠狠色丁香久久婷婷综 | 欧美日韩一区二区三区久久 | 久久毛片免费看一区二区三区 | 老司机亚洲精品影院 | 欧美一级片免费 | 亚洲成a人片在线观 | 欧美日韩一区二区视频免费看 | 99在线视频精品 | wwwav在线| 色色视频免费网 | 国产精品久久久久久久久免费 | 欧美hdvideosex4k| 国产深夜福利视频网站在线观看 | 一区二区在线播放福利视频 |