spring aop expression簡單說明


<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...");
    }

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM