spring aop execution表達(dá)式的用法
1.切所有controller下的請求
項(xiàng)目結(jié)構(gòu)

任意公共方法的執(zhí)行:
execution(public * (…))
##public可以省略, 第一個 代表方法的任意返回值 第二個參數(shù)代表任意包+類+方法 (…)任意參數(shù)
配置切入點(diǎn):
@Pointcut("execution(* com.gcol.qy.web.system.controller..*.*(..))")
public void conPoint(){}
表達(dá)式結(jié)構(gòu)解釋如下:
| 標(biāo)識符 | 含義 |
|---|---|
| execution() | 表達(dá)式的主體 |
| 第一個“ * ”符號 | 表示返回值的類型任意 |
| com.gcol.qy.web.system.controller | AOP所切的服務(wù)的包名,即,需要進(jìn)行橫切的業(yè)務(wù)類 |
| 包名后面的“..” | 表示當(dāng)前包及子包 |
| 第二個“*” | 表示類名,*即所有類 |
| .*(..) | 表示任何方法名,括號表示參數(shù),兩個點(diǎn)表示任何參數(shù)類型 |
如果需要多個切入點(diǎn)可以用 || 符號 如下:
@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(修飾符 返回類型 切入點(diǎn)類 切入點(diǎn)方法(參數(shù)) 異常拋出)
- 修飾符: 可選,支持通配符,(public/private/protected)
- 返回類型: 必填,支持通配符,可以使用 * 來匹配所有的返回值類型
- 切入點(diǎn)類: 可選,支持通配符,指定切入點(diǎn)類
- 切入點(diǎn)方法: 必填,支持通配符,指定要匹配的方法名,可以使用"*"通配符來匹配所有方法
- 參數(shù): 若無可不填,指定方法聲明中的形參列表,支持兩個通配符,即*和…
其中*代表一個任意類型的參數(shù),而…代表零個或多個任意類型的參數(shù)
- () 匹配一個不接受任何參數(shù)的方法
- (…) 匹配一個接受任意數(shù)量參數(shù)的方法,可以是零個或多個
- (*) 匹配一個接受一個任何類型的參數(shù)的方法,只能是一個
- (*,String) 匹配一個接受兩個參數(shù)的方法,其中第一個參數(shù)是任意類型,第二個參數(shù)必須是String類型
異常拋出: 可選,支持通配符,指定方法聲明拋出的異常
常用實(shí)例
<!-- 【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)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
- Spring-AOP @AspectJ切點(diǎn)函數(shù)之@annotation()用法
- SpringAOP切點(diǎn)函數(shù)實(shí)現(xiàn)原理詳解
- Spring AOP中定義切點(diǎn)的實(shí)現(xiàn)方法示例
- Spring AOP如何在注解上使用SPEL表達(dá)式注入對象
- SpringBoot?AOP?@Pointcut切入點(diǎn)表達(dá)式排除某些類方式
- SpringAop切入點(diǎn)execution表達(dá)式的深入講解
- Spring-AOP 靜態(tài)正則表達(dá)式方法如何匹配切面
- Spring AOP中使用args表達(dá)式的方法示例
- Spring中AOP的切點(diǎn)、通知、切點(diǎn)表達(dá)式及知識要點(diǎn)整理
相關(guān)文章
java獲取鍵盤輸入的數(shù)字,并進(jìn)行排序的方法
今天小編就為大家分享一篇java獲取鍵盤輸入的數(shù)字,并進(jìn)行排序的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07
springboot整合shardingjdbc實(shí)現(xiàn)分庫分表最簡單demo
我們知道分庫分表是針對某些數(shù)據(jù)量持續(xù)大幅增長的表,比如用戶表、訂單表等,而不是一刀切將全部表都做分片,這篇文章主要介紹了springboot整合shardingjdbc實(shí)現(xiàn)分庫分表最簡單demo,需要的朋友可以參考下2021-06-06
java 裝飾模式(Decorator Pattern)詳解
這篇文章主要介紹了java 裝飾模式(Decorator Pattern)詳解的相關(guān)資料,需要的朋友可以參考下2016-10-10

