Spring中通配符问题

一、加载路径中的通配符

(1)?(匹配单个字符)

(2)*(匹配除/外任意字符)

(3)**/(匹配任意多个目录)

示例:

1)classpath:app-Beans.xml

说明:无通配符,必须完全匹配

(2)classpath:App?-Beans.xml

说明:匹配一个字符,例如 App1-Beans.xml 、 App2-Beans.xml

(3)classpath:user/*/Base-Beans.xml

说明:匹配零个或多个字符串(只针对名称,不匹配目录分隔符等),例如:user/a/Base-Beans.xml 、 user/b/Base-Beans.xml ,但是不匹配 user/Base-Beans.xml

(4)classpath:user/**/Base-Beans.xml

说明:匹配路径中的零个或多个目录,例如:user/a/ab/abc/Base-Beans.xml,同时也能匹配 user/Base-Beans.xml

(5)classpath:**/*-Beans.xml

说明:表示在所有的类路径中查找和加载文件名以“-Beans.xml”结尾的配置文件,但重复的文件名只加载其中一个,视加载顺序决定

(6)classpath*:user/**/*-Beans.xml

    classpath*:**/*-Beans.xml

说明:“classpath*:”表示加载多个资源文件,即使重名也会被加载,比如app1.jar中有一个config-Beans.xml,app2.jar中也有一个config-Beans.xml,这个时候,两个都会加载。classpath*:可以用来从多个jar文件中加载相同的文件,且可以用来加载其它(非当前)ClassLoader的路径里文件。

二、<context:component-scan base-package=" ">包扫描路径

(1)<context:component-scan base-package="com.*" />

(2)<context:component-scan base-package="com.*.dao" />

(3)<context:component-scan base-package="com.**.dao" />

  说明:“**”标示不确定层包通配,即只扫描dao包(中间有不确定层包)

(4)<context:component-scan base-package="com.*dao" />

  说明:“*dao”以dao结尾的包通配,即只扫描以“dao”结尾的包

三、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编程指南中语言语义的部分。

  下面给出一些通用切入点表达式的例子。

(1)任意公共方法的执行:

execution(public * *(..))

(2)任何一个名字以“set”开始的方法的执行:

execution(* set*(..))

(3)AccountService接口定义的任意方法的执行:

execution(* com.xyz.service.AccountService.*(..))

(4)在service包中定义的任意方法的执行:

execution(* com.xyz.service.*.*(..))

(5)在service包或其子包中定义的任意方法的执行:

execution(* com.xyz.service..*.*(..))

(6)在service包中的任意连接点(在Spring AOP中只是方法执行):

within(com.xyz.service.*)

(7)在service包或其子包中的任意连接点(在Spring AOP中只是方法执行):

within(com.xyz.service..*)

(8)实现了AccountService接口的代理对象的任意连接点 (在Spring AOP中只是方法执行):

this(com.xyz.service.AccountService)

  ‘this‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得代理对象在通知体内可用。

(9)实现AccountService接口的目标对象的任意连接点 (在Spring AOP中只是方法执行):

target(com.xyz.service.AccountService)

  ‘target‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得目标对象在通知体内可用。

(10)任何一个只接受一个参数,并且运行时所传入的参数是Serializable 接口的连接点(在Spring AOP中只是方法执行)

args(java.io.Serializable)

  ‘args‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得方法参数在通知体内可用。

  请注意在例子中给出的切入点不同于 execution(* *(java.io.Serializable)): args版本只有在动态运行时候传入参数是Serializable时才匹配,而execution版本在方法签名中声明只有一个 Serializable类型的参数时候匹配。

(11)目标对象中有一个 @Transactional 注解的任意连接点 (在Spring AOP中只是方法执行)

@target(org.springframework.transaction.annotation.Transactional)

  ‘@target‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得注解对象在通知体内可用。

(12)任何一个目标对象声明的类型有一个 @Transactional 注解的连接点 (在Spring AOP中只是方法执行):

@within(org.springframework.transaction.annotation.Transactional)

  ‘@within‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得注解对象在通知体内可用。

(13)任何一个执行的方法有一个 @Transactional 注解的连接点 (在Spring AOP中只是方法执行)

@annotation(org.springframework.transaction.annotation.Transactional)

  ‘@annotation‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得注解对象在通知体内可用。

(14)任何一个只接受一个参数,并且运行时所传入的参数类型具有@Classified 注解的连接点(在Spring AOP中只是方法执行)

@args(com.xyz.security.Classified)

  ‘@args‘在绑定表单中更加常用:- 请参见后面的通知一节中了解如何使得注解对象在通知体内可用。

(15)任何一个在名为‘tradeService‘的Spring bean之上的连接点 (在Spring AOP中只是方法执行)。

bean(tradeService)

(16)任何一个在名字匹配通配符表达式‘*Service‘的Spring bean之上的连接点 (在Spring AOP中只是方法执行)

bean(*Service)

原文地址:https://www.cnblogs.com/javahr/p/8383543.html

时间: 2024-11-05 14:27:22

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 . us

Spring中加载xml配置文件的六种方式

因为目前正在从事一个项目,项目中一个需求就是所有的功能都是插件的形式装入系统,这就需要利用Spring去动态加载某一位置下的配置文件,所以就总结了下Spring中加载xml配置文件的方式,我总结的有6种, xml是最常见的spring 应用系统配置源.Spring中的几种容器都支持使用xml装配bean,包括: XmlBeanFactory,ClassPathXmlApplicationContext,FileSystemXmlApplicationContext,XmlWebApplicati

Spring中对资源的读取支持

Resource简单介绍 注:所有操作基于配置好的Spring开发环境中. 在Spring中,最为核心的部分就是applicationContext.xml文件,而此配置文件中字符串的功能发挥到了极致. 在Java里面提供了最为原始的IO处理操作支持,但是传统的java.io包中只提供了inputStream与outputStream,虽然是最为常用的输入输出的处理类,但是用其进行一些复杂的资源读取非常麻烦.所以使用PrintStream,Scanner来改善这样的操作处理.但是即便这样,对网络

Spring中资源的加载ResourceLoader

Spring中资源的加载是定义在ResourceLoader接口中的,它跟前面提到的抽象资源的关系如下: ResourceLoader的源码 [java] view plain copy public interface ResourceLoader { /** Pseudo URL prefix for loading from the class path: "classpath:" */ String CLASSPATH_URL_PREFIX = ResourceUtils.CL

深入分析JavaWeb Item54 -- Spring中的AOP面向切面编程2

一.在Advice方法中获取目标方法的参数 1.获取目标方法的信息 访问目标方法最简单的做法是定义增强处理方法时,将第一个参数定义为JoinPoint类型,当该增强处理方法被调用时,该JoinPoint参数就代表了织入增强处理的连接点.JoinPoint里包含了如下几个常用的方法: Object[] getArgs:返回目标方法的参数 Signature getSignature:返回目标方法的签名 Object getTarget:返回被织入增强处理的目标对象 Object getThis:返

spring中 context:property-placeholder 导入多个独立的配置文件

spring中 context:property-placeholder 导入多个独立的 .properties配置文件? Spring容器采用反射扫描的发现机制,在探测到Spring容器中有一个 org.springframework.beans.factory.config.PropertyPlaceholderConfigurer的 Bean就会停止对剩余PropertyPlaceholderConfigurer的扫描(Spring 3.1已经使用PropertySourcesPlaceh

[转]Spring中的ContextLoaderListener使用

最近 项目中使用Spring 时,applicationContext.xml配置文件中并没有BeanFactory,要想在业务层中的class 文件中直接引用Spring容器管理的bean可通过以下方式 1.在web.xml配置监听器ContextLoaderListener <listener>   <listener-class>org.springframework.web.context.ContextLoaderListener </listener-class&

Spring中AOP简介与使用

Spring中AOP简介与使用 什么是AOP? Aspect Oriented Programming(AOP),多译作 "面向切面编程",也就是说,对一段程序,从侧面插入,进行操做.即通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术. 为什么要用AOP? 日志记录,性能统计,安全控制,事务处理,异常处理等等.例如日志记录,在程序运行的某些节点上添加记录执行操作状态的一些代码,获取执行情况.而通过切面编程,我们将这些插入的内容分离出来,将它们独立

Spring中ClassPathXmlApplicationContext类的简单使用

一.简单的用ApplicationContext做测试的话,获得Spring中定义的Bean实例(对象).可以用: ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");RegisterDAO registerDAO = (RegisterDAO)ac.getBean("RegisterDAO"); 如果是两个以上:ApplicationContext