springboot?aop里的@Pointcut()的配置方式
springboot aop里的@Pointcut()的配置
@Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.test(String,String))")
com.wangzhou.newboot.exception是TestExceptionController類的全路徑,test(String,String)是TestExceptionController類下的
test(String s,String d)方法
如果要忽略test方法的入?yún)ⅲ衪est方法將被aop
@Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.test(..))")
如果忽略TestExceptionController的方法,所有TestExceptionController下的方法將被aop
@Pointcut("execution(public * com.wangzhou.newboot.exception.TestExceptionController.*(..))")
如果忽略exception路徑下的所有類,不包括exception的子路徑
@Pointcut("execution(public * com.wangzhou.newboot.exception.*.*(..))")
如果忽略newboot路徑下的所有類,不包括newboot的子路徑比如exception里的類,
@Pointcut("execution(public * com.wangzhou.newboot..*.*(..))")
springboot aop @Pointcut的用法
格式:
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?)
括號中各個(gè)pattern分別表示:
- 修飾符匹配(modifier-pattern?)
- 返回值匹配(ret-type-pattern)可以為*表示任何返回值,全路徑的類名等
- 類路徑匹配(declaring-type-pattern?)
- 方法名匹配(name-pattern)可以指定方法名 或者 *代表所有, set* 代表以set開頭的所有方法
- 參數(shù)匹配((param-pattern))可以指定具體的參數(shù)類型,多個(gè)參數(shù)間用“,”隔開,各個(gè)參數(shù)也可以用“*”來表示匹配任意類型的參數(shù),如(String)表示匹配一個(gè)String參數(shù)的方法;(*,String) 表示匹配有兩個(gè)參數(shù)的方法,第一個(gè)參數(shù)可以是任意類型,而第二個(gè)參數(shù)是String類型;可以用(..)表示零個(gè)或多個(gè)任意參數(shù)
- 異常類型匹配(throws-pattern?)
- 其中后面跟著“?”的是可選項(xiàng)
現(xiàn)在來看看幾個(gè)例子:
1)execution(* *(..)) //表示匹配所有方法 2)execution(public * com. savage.service.UserService.*(..)) //表示匹配com.savage.server.UserService中所有的公有方法 3)execution(* com.savage.server..*.*(..)) //表示匹配com.savage.server包及其子包下的所有方法
在Spring 2.0中,Pointcut的定義包括兩個(gè)部分:Pointcut表示式(expression)和Pointcut簽名(signature)
//Pointcut表示式 @Pointcut("execution(* com.savage.aop.MessageSender.*(..))") //Point簽名 private void log(){}
然后要使用所定義的Pointcut時(shí),可以指定Pointcut簽名
如下:
@Before("og()")
這種使用方式等同于以下方式,直接定義execution表達(dá)式使用
@Before("execution(* com.savage.aop.MessageSender.*(..))")
Pointcut定義時(shí),還可以使用&&、||、! 這三個(gè)運(yùn)算
@Pointcut("execution(* com.savage.aop.MessageSender.*(..))") private void logSender(){} @Pointcut("execution(* com.savage.aop.MessageReceiver.*(..))") private void logReceiver(){} @Pointcut("logSender() || logReceiver()") private void logMessage(){}
這個(gè)例子中,logMessage()將匹配任何MessageSender和MessageReceiver中的任何方法。
還可以將一些公用的Pointcut放到一個(gè)類中,以供整個(gè)應(yīng)用程序使用,如下:
package com.savage.aop; import org.aspectj.lang.annotation.*; public class Pointcuts { @Pointcut("execution(* *Message(..))") public void logMessage(){} @Pointcut("execution(* *Attachment(..))") public void logAttachment(){} @Pointcut("execution(* *Service.*(..))") public void auth(){} }
在使用上面定義Pointcut時(shí),指定完整的類名加上Pointcut簽名就可以了,如:
package com.savage.aop; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.*; @Aspect public class LogBeforeAdvice { @Before("com.sagage.aop.Pointcuts.logMessage()") public void before(JoinPoint joinPoint) { System.out.println("Logging before " + joinPoint.getSignature().getName()); } }
當(dāng)基于XML Sechma實(shí)現(xiàn)Advice時(shí),如果Pointcut需要被重用,可以使用<aop:pointcut></aop:pointcut>來聲明Pointcut,然后在需要使用這個(gè)Pointcut的地方,用pointcut-ref引用就行了,如:
<aop:config> <aop:pointcut id="log" expression="execution(* com.savage.simplespring.bean.MessageSender.*(..))"/> <aop:aspect id="logging" ref="logBeforeAdvice"> <aop:before pointcut-ref="log" method="before"/> <aop:after-returning pointcut-ref="log" method="afterReturning"/> </aop:aspect> </aop:config>
另外,除了execution表示式外,還有within、this、target、args等Pointcut表示式
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- SpringBoot中使用?POI的示例代碼
- SpringBoot EasyPoi動態(tài)導(dǎo)入導(dǎo)出的兩種方式實(shí)現(xiàn)方法詳解
- SpringBoot如何基于POI-tl和word模板導(dǎo)出龐大的Word文件
- SpringBoot集成POI實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出的示例詳解
- SpringBoot?AOP?@Pointcut切入點(diǎn)表達(dá)式排除某些類方式
- springboot中EasyPoi實(shí)現(xiàn)自動新增序號的方法
- 淺談springboot之JoinPoint的getSignature方法
- SpringBoot中使用JeecgBoot的Autopoi導(dǎo)出Excel的方法步驟
- springboot中poi使用操作方法
相關(guān)文章
Java 數(shù)據(jù)結(jié)構(gòu)線性表之順序存儲詳解原理
線性表的順序存儲是指用一組地址連續(xù)的存儲單元依次存儲線性表中的各個(gè)元素、使得線性表中在邏輯結(jié)構(gòu)上相鄰的數(shù)據(jù)元素存儲在相鄰的物理存儲單元中,即通過數(shù)據(jù)元素物理存儲的相鄰關(guān)系來反映數(shù)據(jù)元素之間邏輯上的相鄰關(guān)系2021-10-10Java實(shí)現(xiàn)Map集合遍歷的四種常見方式與用法分析
這篇文章主要介紹了Java實(shí)現(xiàn)Map集合遍歷的四種常見方式與用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了java針對Map集合鍵值對遍歷的常見使用技巧與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2018-01-01如何把Spring Cloud Data Flow部署在Kubernetes上
這篇文章主要介紹了把Spring Cloud Data Flow部署在Kubernetes上,再跑個(gè)任務(wù)試試,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08springboot發(fā)布dubbo服務(wù)注冊到nacos實(shí)現(xiàn)方式
這篇文章主要介紹了springboot發(fā)布dubbo服務(wù)注冊到nacos實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09關(guān)于Java Guava ImmutableMap不可變集合源碼分析
這篇文章主要介紹Java Guava不可變集合ImmutableMap的源碼分析的相關(guān)資料,需要的朋友可以參考下面具體的文章內(nèi)容2021-09-09