<aop:config> <aop:pointcut id="userDAO" expression="execution(public * cn.dao.IUserDAO.*(..))" /> <aop:advisor advice-ref="tx" pointcut-ref="userDAO"/> </aop:config>
在上面的程式碼中
execution 是方法執行
public 是指定public的方法,也可以不寫直接:execution(* cn.dao.IUserDAO.*(..)
* 是任意返回值,可以有返回值,也可以是void沒有返回值的方法
cn.dao.IUserDAO.* 是指定目錄下的指定類任意方法
cn.dao.IUserDAO.insert* 是指定目錄下的指定類insert開頭的任意方法
cn.dao.IUserDAO.*.* 是指定目錄下的任意類下的任意方法
cn.dao..*.* 是指定目錄下的任意目錄下任意類下的任意方法
(..) 是任何引數,可以是沒有引數
在execution中是可以有多個的方法,例如:
execution(* com.action.userinfoAction..*(..))&&execution(* com.action.memberAction..*(..))&&!execution(* get*(..))&&!execution(* set*(..))
Pointcut 是指那些方法需要被執行"AOP",是由"Pointcut Expression"來描述的. Pointcut可以有下列方式來定義或者通過&& || 和!的方式進行組合. args() @args() execution() this() target() @target() within() @within() @annotation 其中execution 是用的最多的,其格式為: execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)throws-pattern?) returning type pattern,name pattern, and parameters pattern是必須的. ret-type-pattern:可以為*表示任何返回值,全路徑的類名等. name-pattern:指定方法名,*代表所以,set*,代表以set開頭的所有方法. parameters pattern:指定方法引數(宣告的型別),(..)代表所有引數,(*)代表一個引數,(*,String)代表第一個引數為任何值,第二個為String型別. 舉例說明: 任意公共方法的執行: execution(public * *(..)) 任何一個以“set”開始的方法的執行: execution(* set*(..)) AccountService 介面的任意方法的執行: execution(* com.xyz.service.AccountService.*(..)) 定義在service包裡的任意方法的執行: execution(* com.xyz.service.*.*(..)) 定義在service包和所有子包裡的任意類的任意方法的執行: execution(* com.xyz.service..*.*(..)) 定義在pointcutexp包和所有子包裡的JoinPointObjP2類的任意方法的執行: execution(* com.test.spring.aop.pointcutexp..JoinPointObjP2.*(..))") ***> 最靠近(..)的為方法名,靠近.*(..))的為類名或者介面名,如上例的JoinPointObjP2.*(..))
pointcutexp包裡的任意類. within(com.test.spring.aop.pointcutexp.*) pointcutexp包和所有子包裡的任意類. within(com.test.spring.aop.pointcutexp..*) 實現了Intf介面的所有類,如果Intf不是介面,限定Intf單個類. this(com.test.spring.aop.pointcutexp.Intf) ***> 當一個實現了介面的類被AOP的時候,用getBean方法必須cast為介面型別,不能為該類的型別.
帶有@Transactional標註的所有類的任意方法. @within(org.springframework.transaction.annotation.Transactional) @target(org.springframework.transaction.annotation.Transactional) 帶有@Transactional標註的任意方法. @annotation(org.springframework.transaction.annotation.Transactional) ***> @within和@target針對類的註解,@annotation是針對方法的註解
引數帶有@Transactional標註的方法. @args(org.springframework.transaction.annotation.Transactional) 引數為String型別(執行是決定)的方法. args(String) Pointcut 可以通過Java註解和XML兩種方式配置,如下所示:
<aop:config> <aop:aspectref="aspectDef"> <aop:pointcutid="pointcut1"expression="execution(* com.test.spring.aop.pointcutexp..JoinPointObjP2.*(..))"/> <aop:before pointcut-ref="pointcut1" method="beforeAdvice" /> </aop:aspect> </aop:config> @Component @Aspect public class AspectDef { //@Pointcut("execution(* com.test.spring.aop.pointcutexp..JoinPointObjP2.*(..))") //@Pointcut("within(com.test.spring.aop.pointcutexp..*)") //@Pointcut("this(com.test.spring.aop.pointcutexp.Intf)") //@Pointcut("target(com.test.spring.aop.pointcutexp.Intf)") //@Pointcut("@within(org.springframework.transaction.annotation.Transactional)") //@Pointcut("@annotation(org.springframework.transaction.annotation.Transactional)") @Pointcut("args(String)") public void pointcut1() { } @Before(value = "pointcut1()") public void beforeAdvice() { System.out.println("pointcut1 @Before..."); }