Spring中的通配符

 

Spring中通配符

一、加載路徑中的通配符:?(匹配單個字符),*(匹配除/外任意字符)、**/(匹配任意多個目錄)

classpath:app-Beans.xml

說明:無通配符,必須完全匹配
classpath:App?-Beans.xml
說明:匹配一個字符,例如 App1-Beans.xml 、 App2-Beans.xml
classpath:user/*/Base-Beans.xml
說明:匹配零個或多個字符串(只針對名稱,不匹配目錄分隔符等),例如:user/a/Base-Beans.xml 、 user/b/Base-Beans.xml ,但是不匹配 user/Base-Beans.xml
classpath:user/**/Base-Beans.xml
說明:匹配路徑中的零個或多個目錄,例如:user/a/ab/abc/Base-Beans.xml,同時也能匹配 user/Base-Beans.xml
classpath:**/*-Beans.xml
說明:表示在所有的類路徑中查找和加載文件名以“-Beans.xml”結尾的配置文件,但重複的文件名只加載其中一個,視加載順序決定
classpath*:user/**/*-Beans.xml
classpath*:**/*-Beans.xml
說明:“classpath*:”表示加載多個資源文件,即使重名也會被加載,比如app1.jar中有一個config-Beans.xml,app2.jar中也有一個config-Beans.xml,這個時候,兩個都會加載。classpath*:可以用來從多個jar文件中加載相同的文件,且可以用來加載其它(非當前)ClassLoader的路徑裏文件。

注意Spring中路徑分割符爲/,而不能用\\,參考:http://mushiqianmeng.blog.51cto.com/3970029/875027/

二、Spring AOP配置通配符 :
以下文檔來自Spring中文開發指南2.5文檔,由滿江紅開源組織翻譯:
Spring AOP 用戶可能會經常使用 execution切入點指示符。執行表達式的格式如下:
execution(modifiers-pattern? ret-type-pattern declaring-type-pattern? name-pattern(param-pattern)
          throws-pattern?)
除了返回類型模式(上面代碼片斷中的ret-type-pattern),名字模式和參數模式以外, 所有的部分都是可選的。返回類型模式決定了方法的返回類型必須依次匹配一個連接點。 你會使用的最頻繁的返回類型模式是*,它代表了匹配任意的返回類型。 一個全限定的類型名將只會匹配返回給定類型的方法。名字模式匹配的是方法名。 你可以使用*通配符作爲所有或者部分命名模式。 參數模式稍微有點複雜:()匹配了一個不接受任何參數的方法, 而(..)匹配了一個接受任意數量參數的方法(零或者更多)。 模式(*)匹配了一個接受一個任何類型的參數的方法。 模式(*,String)匹配了一個接受兩個參數的方法,第一個可以是任意類型, 第二個則必須是String類型。更多的信息請參閱AspectJ編程指南中 語言語義的部分。
下面給出一些通用切入點表達式的例子。
  • 任意公共方法的執行:
    execution(public * *(..))
  • 任何一個名字以“set”開始的方法的執行:
    execution(* set*(..))
  • AccountService接口定義的任意方法的執行:
    execution(* com.xyz.service.AccountService.*(..))
  • 在service包中定義的任意方法的執行:
    execution(* com.xyz.service.*.*(..))
  • 在service包或其子包中定義的任意方法的執行:
    execution(* com.xyz.service..*.*(..))
  • 在service包中的任意連接點(在Spring AOP中只是方法執行):
    within(com.xyz.service.*)
  • 在service包或其子包中的任意連接點(在Spring AOP中只是方法執行):
    within(com.xyz.service..*)
  • 實現了AccountService接口的代理對象的任意連接點 (在Spring AOP中只是方法執行):
    this(com.xyz.service.AccountService)
    'this'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得代理對象在通知體內可用。
  • 實現AccountService接口的目標對象的任意連接點 (在Spring AOP中只是方法執行):
    target(com.xyz.service.AccountService)
    'target'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得目標對象在通知體內可用。
  • 任何一個只接受一個參數,並且運行時所傳入的參數是Serializable 接口的連接點(在Spring AOP中只是方法執行)
    args(java.io.Serializable)
    'args'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得方法參數在通知體內可用。
    請注意在例子中給出的切入點不同於 execution(* *(java.io.Serializable)): args版本只有在動態運行時候傳入參數是Serializable時才匹配,而execution版本在方法簽名中聲明只有一個 Serializable類型的參數時候匹配。
  • 目標對象中有一個 @Transactional 註解的任意連接點 (在Spring AOP中只是方法執行)
    @target(org.springframework.transaction.annotation.Transactional)
    '@target'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得註解對象在通知體內可用。
  • 任何一個目標對象聲明的類型有一個 @Transactional 註解的連接點 (在Spring AOP中只是方法執行):
    @within(org.springframework.transaction.annotation.Transactional)
    '@within'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得註解對象在通知體內可用。
  • 任何一個執行的方法有一個 @Transactional 註解的連接點 (在Spring AOP中只是方法執行)
    @annotation(org.springframework.transaction.annotation.Transactional)
    '@annotation'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得註解對象在通知體內可用。
  • 任何一個只接受一個參數,並且運行時所傳入的參數類型具有@Classified 註解的連接點(在Spring AOP中只是方法執行)
    @args(com.xyz.security.Classified)
    '@args'在綁定表單中更加常用:- 請參見後面的通知一節中瞭解如何使得註解對象在通知體內可用。
  • 任何一個在名爲'tradeService'的Spring bean之上的連接點 (在Spring AOP中只是方法執行):
    bean(tradeService)
  • 任何一個在名字匹配通配符表達式'*Service'的Spring bean之上的連接點 (在Spring AOP中只是方法執行):
    bean(*Service)

     
 


 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章