自從使用 AspectJ 風格切面配置,使得 spring 的切面配置大大簡化,但是 AspectJ 是另外一個開源項目,其規則表達式的語法也稍稍有些怪異。
下面給出一些常見示例的寫法,例如,下面是一個對 Service 包上所有方法的切面配置:
1
2
3
4
|
< aop:config > < aop:pointcut id = "serviceOperation" expression = "execution(* *..service*..*(..))" /> < aop:advisor pointcut-ref = "serviceOperation" advice-ref = "txAdvice" /> </ aop:config > |
表達式所處位置如上pointcut的位置。配置這個是為了更好控制切面上的事務,下面是一個事物配置的簡單例子:
1
2
3
4
5
6
7
8
|
< tx:advice id = "txAdvice" transaction-manager = "transactionManager" > < tx:attributes > < tx:method name = "delete*" rollback-for = "Exception" /> < tx:method name = "save*" rollback-for = "Exception" /> < tx:method name = "update*" rollback-for = "Exception" /> < tx:method name = "*" read-only = "true" rollback-for = "Exception" /> </ tx:attributes > </ tx:advice > |
通過切面、通知的配置,就為所有的以delete、save和update開頭的方法添加上了一致性事務,對其他方法添加上了只讀事務。
這個還不夠細,如果要寫更為詳細的控制,就需要研究 AspectJ 切點配置的語法了,其實研究這些標準,還不如拿幾個例子看看,解決實際問題就行了。就像寫正則表達式一樣,標準明擺著,要寫好卻不容易,從例子著手就能快速上手和領悟。
以下文檔來自 Spring 中文開發指南 2.5 文檔,由滿江紅開源組織翻譯:
Spring AOP 用戶可能會經常使用 execution 切入點指示符。執行表達式的格式如下:
1
2
3
|
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern) throws -pattern?) |
除了返回類型模式(上面代碼片斷中的 ret-type-pattern),名字模式和參數模式以外, 所有的部分都是可選的。返回類型模式決定了方法的返回類型必須依次匹配一個連接點。 你會使用的最頻繁的返回類型模式是*,它代表了匹配任意的返回類型。 一個全限定的類型名將只會匹配返回給定類型的方法。名字模式匹配的是方法名。你可以使用*通配符作為所有或者部分命名模式。 參數模式稍微有點復雜,()匹配了一個不接受任何參數的方法, 而(..)則匹配了一個接受任意數量參數的方法(零或者更多)。模式(*)匹配了一個接受一個任何類型的參數的方法。 模式(*,String)匹配了一個接受兩個參數的方法,第一個可以是任意類型, 第二個則必須是 String 類型。更多的信息請參閱 AspectJ 編程指南中 語言語義的部分。下面給出一些通用切入點表達式的例子。
任意公共方法的執行:
1
|
execution( public * *(..)) |
任何一個名字以 set 開始的方法的執行:
1
|
execution(* set*(..)) |
AccountService 接口定義的任意方法的執行:
1
|
execution(* com.xyz.service.AccountService.*(..)) |
在 service 包中定義的任意方法的執行:
1
|
execution(* com.xyz.service.*.*(..)) |
在 service 包或其子包中定義的任意方法的執行:
1
|
execution(* com.xyz.service..*.*(..)) |
在 service 包中的任意連接點(在 Spring AOP 中只是方法執行):
1
|
within(com.xyz.service.*) |
在 service 包或其子包中的任意連接點(在 Spring AOP 中只是方法執行):
1
|
within(com.xyz.service..*) |
實現 AccountService 接口的代理對象的任意連接點 (在 Spring AOP 中只是方法執行):
1
|
this (com.xyz.service.AccountService) |
實現 AccountService 接口的目標對象的任意連接點 (在 Spring AOP 中只是方法執行):
1
|
target(com.xyz.service.AccountService) |
任何一個只接受一個參數,并且運行時所傳入的參數是 Serializable 接口的連接點(在 Spring AOP 中只是方法執行):
1
|
args(java.io.Serializable) |
請注意在例子中給出的切入點不同于execution(* *(Java.io.Serializable)),args 版本只有在動態運行時候傳入參數是 Serializable 時才匹配,而 execution 版本在方法簽名中聲明只有一個 Serializable 類型的參數時候匹配。
目標對象中有一個 @Transactional 注解的任意連接點 (在 Spring AOP 中只是方法執行):
1
|
@target (org.springframework.transaction.annotation.Transactional) |
任何一個目標對象聲明的類型有一個 @Transactional 注解的連接點 (在 Spring AOP 中只是方法執行):
1
|
@within (org.springframework.transaction.annotation.Transactional) |
任何一個執行的方法有一個 @Transactional 注解的連接點 (在 Spring AOP 中只是方法執行):
1
|
@annotation (org.springframework.transaction.annotation.Transactional) |
任何一個只接受一個參數,并且運行時所傳入的參數類型具有 @Classified 注解的連接點(在 Spring AOP 中只是方法執行):
1
|
@args (com.xyz.security.Classified) |
任何一個在名為 tradeService 的 Spring bean 之上的連接點 (在 Spring AOP 中只是方法執行):
1
|
bean(tradeService) |
任何一個在名字匹配通配符表達式*Service的 Spring bean 之上的連接點 (在 Spring AOP 中只是方法執行):
1
|
bean(*Service) |
其中,this
、tagart
、args
、 @target
、 @with
、 @annotation
和@args
在綁定表單中更加常用。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/qq_35246620/article/details/68942609