Spring可以通过指定classpath*:与classpath:前缀加路径的方式从classpath加载文件,如bean的定义文件.
classpath*:的出现是为了从多个jar文件中加载相同的文件.
classpath:只能加载找到的第一个文件.
比如 resource1.jar中的package 'com.test.rs' 有一个 'jarAppcontext.xml' 文件,内容如下:
<bean name="ProcessorImplA" class="com.test.spring.di.ProcessorImplA" />
resource2.jar中的package 'com.test.rs' 也有一个 'jarAppcontext.xml' 文件,内容如下:
<bean id="ProcessorImplB" class="com.test.spring.di.ProcessorImplB" />
通过使用下面的代码则可以将两个jar包中的文件都加载进来
ApplicationContext ctx = new ClassPathXmlApplicationContext( "classpath*:com/test/rs/jarAppcontext.xml");
而如果写成下面的代码,就只能找到其中的一个xml文件(顺序取决于jar包的加载顺序)
ApplicationContext ctx = new ClassPathXmlApplicationContext( "classpath:com/test/rs/jarAppcontext.xml");
classpath*:的使用是为了多个component(最终发布成不同的jar包)并行开发,各自的bean定义文件按照一定的规则:package+filename,而使用这些component的调用者可以把这些文件都加载进来.classpath*:的加载使用了classloader的 getResources()
方法,如果是在不同的J2EE服务器上运行,由于应用服务器提供自己的classloader实现,它们在处理jar文件时的行为也许会有所不同。 要测试classpath*:
是否有效,可以用classloader从classpath中的jar文件里加载文件来进行测试:getClass().getClassLoader().getResources("<someFileInsideTheJar>")
。(上面的例子是在sun的jre中运行的状态)
从Spring的源码,在PathMatchingResourcePatternResolver类中,我们可以更清楚的了解其对的处理:如果是以classpath*开头,它会遍历classpath.
protected Resource[] findAllClassPathResources(String location) throws IOException { String path = location; if (path.startsWith("/")) { path = path.substring(1); } Enumeration resourceUrls = getClassLoader().getResources(path); Set<Resource> result = new LinkedHashSet<Resource>(16); while (resourceUrls.hasMoreElements()) { URL url = (URL) resourceUrls.nextElement(); result.add(convertClassLoaderURL(url)); } return result.toArray(new Resource[result.size()]); }另外在加载resource的时候,其他前缀的意义如下表所示:注意classpath*:只能用与指定配置文件的路径,不能用在用于 getResource的参数.如 appContext.getResource("classpath*:conf/bfactoryCtx.xml")会异常的.
classpath: |
|
从classpath中加载。 |
file: |
|
|
http: |
|
作为 |
(none) |
|
根据 |
从Spring的源码可以看出原因:如果是classpath:开头,从classpath加载,否则尝试URL,如果失败,调用 getResourceByPath
public Resource getResource(String location) { Assert.notNull(location, "Location must not be null"); if (location.startsWith(CLASSPATH_URL_PREFIX)) { return new ClassPathResource(location.substring(CLASSPATH_URL_PREFIX.length()), getClassLoader()); } else { try { // Try to parse the location as a URL... URL url = new URL(location); return new UrlResource(url); } catch (MalformedURLException ex) { // No URL -> resolve as resource path. return getResourceByPath(location); } } }getResourceByPath会被不同
ApplicationContext
实现覆盖.
如 GenericWebApplicationContext覆盖为如下:
如ClassPathResource得到inputstream的方法是利用class loader.
public InputStream getInputStream() throws IOException { return new FileInputStream(this.file); }如ServletContextResource得到inputstream的方法是利用servletContext.getResourceAsStream.
相关推荐
Spring 配置中的classpath:与classpath*:的区别 Spring 配置中的classpath:与classpath*:的区别是 Spring 框架中一个常见的问题。本文主要介绍了这两种路径的区别、使用场景及注意事项,以帮助读者更好地理解和使用...
springboot mybatis management: security: enabled: false spring: profiles: active: local application: name: hh-store ... multipart: ... config: classpath:log4j2-${spring.profiles.active}.yml
- **非侵入式**:Spring 不要求任何特定的类继承或实现特定接口,这使得现有代码可以很容易地与Spring集成。 - **IOC容器**:Spring 提供了强大的依赖注入功能,使得对象之间的耦合度大大降低。 - **AOP支持**:...
在Spring MVC项目中,加载jar包中的Spring配置文件是一个常见的需求,特别是在进行SSM(Spring、Spring MVC、MyBatis)整合时。SSM框架的整合通常涉及到多个配置文件的组织和管理,其中一部分配置可能会被打包到独立...
3. **`classpath*:`前缀**:这个前缀与`classpath:`类似,但有一个重要的区别。`classpath*:`不仅会查找类路径下的指定资源,还会递归地查找所有jar包和目录下的匹配文件。这意味着如果你有多个相同命名的配置文件...
### MyEclipse配置环境详解 ...通过以上步骤,不仅能够顺利完成MyEclipse2013的基础配置与优化,还能掌握如何利用Spring Eclipse高效地创建和管理Maven项目,以及配置Tomcat服务器,从而为开发工作提供强大的支持。
- **定义**:使用`classpath*:`, Spring会搜索整个类路径(包括项目本身及所有依赖的第三方库)中同名的资源文件,并将其合并为一个集合来处理。 - **应用场景**:当需要同时考虑项目内部配置文件与外部依赖库中...
- **多态**: 多态的实现方式、重写与重载的区别 **6. 集合** - **集合框架**: ArrayList, LinkedList, HashSet, HashMap等 - **迭代器**: 使用Iterator遍历集合 **7. 异常处理** - **异常分类**: 运行时异常与非...
- **应用程序类加载器(Application ClassLoader)**:默认类加载器,加载应用程序 ClassPath 下的类。 #### 2. JVM 架构 Java 虚拟机 (JVM) 是运行 Java 字节码的虚拟执行环境。JVM 架构包括: - **类加载器子系统**...
- **配置CLASSPATH**: 配置`CLASSPATH`环境变量,包括`JAVA_HOME`下的`lib`目录中的`dt.jar`和`tools.jar`。 #### 2. 配置Path - 在系统环境变量`path`中添加`%JAVA_HOME%\bin`。 #### 3. 安装STS (Spring Tool ...
spring.thymeleaf.prefix=classpath:/templates/ #spring.thymeleaf.suffix=.jsp spring.thymeleaf.cache=false #mybatis 配置 mybatis.mapper-locations=classpath:mapping/*Mapper.xml mybatis.type-...
- **Spring官方文档**:《Spring Developer Guide》是一本详尽的Spring开发指南,覆盖了Spring的核心组件及其应用场景。 - **在线社区**:如Spring Framework论坛和JavaEye论坛,这些社区是解决具体问题的好地方。...
7. **配置类和@ComponentScan**: 在Spring 3.0引入的@Configuration注解的类中,可以结合@ComponentScan一起使用,这样就不再需要XML配置文件,实现了全注解配置。 8. **工具支持**: 使用IDE如IntelliJ IDEA或...
- **Spring对JavaMail的整合**:通过Spring提供的JavaMailSender接口来简化邮件发送过程。 **10.3 Spring RMI** Spring还支持远程方法调用(RMI): - **Spring RMI**:通过Spring框架支持RMI服务的发布和客户端调用...
- **引入 Spring 的 jar 包**:添加 Spring 框架所需的依赖库到项目的 classpath 中。 - **编写测试代码**:编写简单的 Java 类来测试 Spring 是否能够正确加载和使用 Bean。 - **注意接口的使用**:确保所有的 ...
- **默认值**:`classpath:`(即类路径下的文件) - **示例**: ```properties spring.config.location=file:/path/to/config/ ``` 这样配置后,Spring Boot 会从指定的文件系统路径下加载配置文件。 #### 三、...
1. **不使用通配符**:当配置文件路径不包含通配符时,Spring会直接定位到指定的文件。例如: - 当配置文件直接放置在应用的bin目录下的conf文件夹内时,上述代码将加载该目录下的`application-context.xml`文件。...
MyBatis-Spring 是一个将 MyBatis ORM 框架与 Spring 框架集成的库,使得在 Spring 应用中使用 MyBatis 变得更加方便。mybatis-spring-1.0.2.zip 文件是这个集成库的一个早期版本,适用于 Windows 的不同操作系统。...