面向切面编程AOP的最佳入门示例
1.AOP簡單上手
? ? ? ?AOP(Aspect Oriented Programming),意為:面向切面編程,通過預(yù)編譯方式和運行期動態(tài)代理實現(xiàn)程序功能的統(tǒng)一維護的一種技術(shù)。它通過對既有程序定義一個切入點,然后在其前后切入不同的執(zhí)行內(nèi)容,比如常見的有:打開數(shù)據(jù)庫連接/關(guān)閉數(shù)據(jù)庫連接、打開事務(wù)/關(guān)閉事務(wù)、記錄日志等。AOP可以降低耦合,把通用的業(yè)務(wù)提出來,提高代碼的可重用性,同時提高開發(fā)的效率,使開發(fā)人員只關(guān)心真正的業(yè)務(wù)邏輯.
? ? ? ?@EnableAspectJAutoProxy已經(jīng)默認(rèn)開啟,不需要在啟動類上添加.
? ? ? ?而當(dāng)我們需要使用CGLIB來實現(xiàn)AOP的時候,需要配置spring.aop.proxy-target-class=true.但是注意:高版本spring自動根據(jù)運行類選擇JDK或CGLIB代理,也就是當(dāng)運行類沒有繼承接口,spring也會自動使用CGLIB代理。我們無需設(shè)置proxy-target-class屬性,JDK動態(tài)代理是模擬接口實現(xiàn)的方式,cglib是模擬子類繼承的方式,一般采用前者,因為前者效率高。
2 簡單示例
@Aspect @Component public class LogAspect {@Around(value = "execution(* com.jun.test.microservice..*(..))")public Object doAroundAdvice(ProceedingJoinPoint proceedingJoinPoint){Object returnVal = null;final Logger log = getLog(proceedingJoinPoint);final String methodName = proceedingJoinPoint.getSignature().getName();try {final Object[] args = proceedingJoinPoint.getArgs();final String arguments;if (args == null || args.length == 0) {arguments = "";} else {arguments = Arrays.deepToString(args);}log.info("Entering method [" + methodName + " with arguments [" + arguments + "]");returnVal = proceedingJoinPoint.proceed();return returnVal;} catch (Throwable throwable) {throwable.printStackTrace();} finally {log.info("Leaving method [" + methodName + "] with return value [" + (returnVal != null ? returnVal.toString() : "null") + "].");}return null;}protected Logger getLog(final JoinPoint joinPoint) {final Object target = joinPoint.getTarget();if (target != null) {return LoggerFactory.getLogger(target.getClass());}return LoggerFactory.getLogger(getClass());}}注意
1.當(dāng)有多個切面針對同一個切點時,可以使用@order()來指定執(zhí)行順序,可以理解成多個同心圓,要執(zhí)行的方法為圓心,最外層的order最小。從最外層按照AOP1、AOP2的順序依次執(zhí)行doAround方法,doBefore方法。然后執(zhí)行method方法,最后按照AOP2、AOP1的順序依次執(zhí)行doAfter、doAfterReturn方法。也就是說對多個AOP來說,先before的,一定后after。
2.@Order的作用于可以在類,方法,字段上,但是他指定的是容器中bean的加載順序.
2.自定義注解+AOP
可以通過自定義注解,來更針對性的定義切點.
2.1 首先自定義注解
2.2 定義切面類
實現(xiàn)注有@SystemServiceLog的方法拋出異常時,記錄日志。
2.3 在需要的方法上添加自定義注解
@Service public class UsrServiceImpl implements IUserService {@SystemServiceLog(description = "查詢用戶")public UserAccount getUser(String id){int i = 0/0;return new UserAccount(id,"hello");} }? ? ? ?以上即可.結(jié)合自定義注解和模板,可以實現(xiàn)很多方便的功能,如記錄系統(tǒng)操作日志(添加,刪除等等),記錄異常等.對一些方法都有的邏輯可以提出來,如參數(shù)校驗,限制訪問頻率等.
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的面向切面编程AOP的最佳入门示例的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 使用mybatis中的自定义TypeHa
- 下一篇: spring event的事件驱动模型的