spring aop execution表達式的用法
更新時間:2021年07月17日 16:33:34 作者:小賊驢
這篇文章主要介紹了spring aop execution表達式的用法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
1.切所有controller下的請求
項目結構

任意公共方法的執(zhí)行:
execution(public * (…))
##public可以省略, 第一個 代表方法的任意返回值 第二個參數(shù)代表任意包+類+方法 (…)任意參數(shù)
配置切入點:
@Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..))")
public void conPoint(){}
表達式結構解釋如下:
| 標識符 | 含義 |
|---|---|
| execution() | 表達式的主體 |
| 第一個“ * ”符號 | 表示返回值的類型任意 |
| com.gcol.qy.web.system.controller | AOP所切的服務的包名,即,需要進行橫切的業(yè)務類 |
| 包名后面的“..” | 表示當前包及子包 |
| 第二個“*” | 表示類名,*即所有類 |
| .*(..) | 表示任何方法名,括號表示參數(shù),兩個點表示任何參數(shù)類型 |
如果需要多個切入點可以用 || 符號 如下:
@Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..)) || execution(* com.gcol.qy.web.system.api..*.*(..))")
public void conPoint(){}
xml 配置
<!-- 切換到獲取kpi信息的oracle數(shù)據(jù)庫 --> <aop:config> <aop:aspect id="dataSourceAspect2" ref="dataSourceInterceptor"> <aop:pointcut id="daoThree" expression="execution(* com.gcol.qy.web.system.service.kpi.KpiServiceImpl.*(..)) || execution(* com.gcol.qy.web.system.service.team.TeamServiceImpl.getFamilyPremiun(..)) || execution(* com.gcol.qy.web.system.service.team.TeamServiceImpl.getSalesmanPremium(..))"/> <aop:before pointcut-ref="daoThree" method="setDataSourceKpi"/> </aop:aspect> </aop:config>
ref=“dataSourceInterceptor” 執(zhí)行的方法類。
2.Spring中execution語法
語法格式
execution(修飾符 返回類型 切入點類 切入點方法(參數(shù)) 異常拋出)
- 修飾符: 可選,支持通配符,(public/private/protected)
- 返回類型: 必填,支持通配符,可以使用 * 來匹配所有的返回值類型
- 切入點類: 可選,支持通配符,指定切入點類
- 切入點方法: 必填,支持通配符,指定要匹配的方法名,可以使用"*"通配符來匹配所有方法
- 參數(shù): 若無可不填,指定方法聲明中的形參列表,支持兩個通配符,即*和…
其中*代表一個任意類型的參數(shù),而…代表零個或多個任意類型的參數(shù)
- () 匹配一個不接受任何參數(shù)的方法
- (…) 匹配一個接受任意數(shù)量參數(shù)的方法,可以是零個或多個
- (*) 匹配一個接受一個任何類型的參數(shù)的方法,只能是一個
- (*,String) 匹配一個接受兩個參數(shù)的方法,其中第一個參數(shù)是任意類型,第二個參數(shù)必須是String類型
異常拋出: 可選,支持通配符,指定方法聲明拋出的異常
常用實例
<!-- 【1、攔截所有public方法】 --> <aop:pointcut expression="execution(public * *(..))" id="pt"/> <!-- 【2、攔截所有save開頭的方法】 --> <aop:pointcut expression="execution(* save*(..))" id="pt"/> <!-- 【3、攔截指定類的指定方法, 攔截時候一定要定位到方法】 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/> <!-- 【4、攔截指定類的所有方法】 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.*(..))" id="pt"/> <!-- 【5、攔截指定包,以及其自包下所有類的所有方法】 --> <aop:pointcut expression="execution(* com..*.*(..))" id="pt"/> <!-- 【6、多條件】 --> <!-- 或:|| or --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) || execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) or execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <!-- 且:&& and --> <!-- 語法雖然沒錯,但,沒意義 --> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) && execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <aop:pointcut expression="execution(* com.shore.dao.impl.UserDao.save(..)) and execution(* com.shore.dao.impl.MessageDao.save(..))" id="pt" /> <!-- 【7、取非值:not ! 不攔截指定的規(guī)則,攔截除此之外的所有類的方法】 --> <aop:pointcut expression="!execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/> <!-- 注意not前必須有空格 --> <aop:pointcut expression=" not execution(* com.shore.dao.impl.UserDao.save(..))" id="pt"/>
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo
我們知道分庫分表是針對某些數(shù)據(jù)量持續(xù)大幅增長的表,比如用戶表、訂單表等,而不是一刀切將全部表都做分片,這篇文章主要介紹了springboot整合shardingjdbc實現(xiàn)分庫分表最簡單demo,需要的朋友可以參考下2021-06-06
java 裝飾模式(Decorator Pattern)詳解
這篇文章主要介紹了java 裝飾模式(Decorator Pattern)詳解的相關資料,需要的朋友可以參考下2016-10-10

