`
Notebookdong
  • 浏览: 122235 次
社区版块
存档分类
最新评论

Spring classpath:与classpath*:的区别

阅读更多

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:com/myapp/config.xml

从classpath中加载。

file:

file:/data/config.xml

作为 URL 从文件系统中加载。

http:

http://myserver/logo.png

作为 URL 加载。

(none)

/data/config.xml

根据 ApplicationContext 进行判断。

从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覆盖为如下:

    protected Resource getResourceByPath(String path) {  
            return new ServletContextResource(this.servletContext, path);  
        }  
      
    如 FileSystemXmlApplicationContext覆盖为如下:  
      
    protected Resource getResourceByPath(String path) {  
            if (path != null && path.startsWith("/")) {  
                path = path.substring(1);  
            }  
            return new FileSystemResource(path);  
        }  
 最终从文件加载的时候仍然是JAVA中常见的读取文件的方法:

如ClassPathResource得到inputstream的方法是利用class loader.

    public InputStream getInputStream() throws IOException {  
        InputStream is;  
        if (this.clazz != null) {  
            is = this.clazz.getResourceAsStream(this.path);  
        }  
 如FileSystemResource得到inputstream的方法是利用FileInputStream.

 

public InputStream getInputStream() throws IOException {
        return new FileInputStream(this.file);
    }
 如ServletContextResource得到inputstream的方法是利用servletContext.getResourceAsStream.

 

public InputStream getInputStream() throws IOException {  
    InputStream is = this.servletContext.getResourceAsStream(this.path);  
    if (is == null) {  
        throw new FileNotFoundException("Could not open " + getDescription());  
    }  
    return is;  
}  
 
 
 
分享到:
评论

相关推荐

    浅析Spring配置中的classpath:与classpath*:的区别

    Spring 配置中的classpath:与classpath*:的区别 Spring 配置中的classpath:与classpath*:的区别是 Spring 框架中一个常见的问题。本文主要介绍了这两种路径的区别、使用场景及注意事项,以帮助读者更好地理解和使用...

    springboot框架

    springboot mybatis management: security: enabled: false spring: profiles: active: local application: name: hh-store ... multipart: ... config: classpath:log4j2-${spring.profiles.active}.yml

    Spring从入门到精通

    - **非侵入式**:Spring 不要求任何特定的类继承或实现特定接口,这使得现有代码可以很容易地与Spring集成。 - **IOC容器**:Spring 提供了强大的依赖注入功能,使得对象之间的耦合度大大降低。 - **AOP支持**:...

    如何加载jar包中的spring配置文件

    在Spring MVC项目中,加载jar包中的Spring配置文件是一个常见的需求,特别是在进行SSM(Spring、Spring MVC、MyBatis)整合时。SSM框架的整合通常涉及到多个配置文件的组织和管理,其中一部分配置可能会被打包到独立...

    加载jar包中的spring配置文件

    3. **`classpath*:`前缀**:这个前缀与`classpath:`类似,但有一个重要的区别。`classpath*:`不仅会查找类路径下的指定资源,还会递归地查找所有jar包和目录下的匹配文件。这意味着如果你有多个相同命名的配置文件...

    Myeclipse配置环境

    ### MyEclipse配置环境详解 ...通过以上步骤,不仅能够顺利完成MyEclipse2013的基础配置与优化,还能掌握如何利用Spring Eclipse高效地创建和管理Maven项目,以及配置Tomcat服务器,从而为开发工作提供强大的支持。

    分享Java知识库

    - **定义**:使用`classpath*:`, Spring会搜索整个类路径(包括项目本身及所有依赖的第三方库)中同名的资源文件,并将其合并为一个集合来处理。 - **应用场景**:当需要同时考虑项目内部配置文件与外部依赖库中...

    java从入门到精通笔记

    - **多态**: 多态的实现方式、重写与重载的区别 **6. 集合** - **集合框架**: ArrayList, LinkedList, HashSet, HashMap等 - **迭代器**: 使用Iterator遍历集合 **7. 异常处理** - **异常分类**: 运行时异常与非...

    30种java技术框架图

    - **应用程序类加载器(Application ClassLoader)**:默认类加载器,加载应用程序 ClassPath 下的类。 #### 2. JVM 架构 Java 虚拟机 (JVM) 是运行 Java 字节码的虚拟执行环境。JVM 架构包括: - **类加载器子系统**...

    window安装流程

    - **配置CLASSPATH**: 配置`CLASSPATH`环境变量,包括`JAVA_HOME`下的`lib`目录中的`dt.jar`和`tools.jar`。 #### 2. 配置Path - 在系统环境变量`path`中添加`%JAVA_HOME%\bin`。 #### 3. 安装STS (Spring Tool ...

    springboot+mybatis+内置tomcat示例.rar

    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官方文档**:《Spring Developer Guide》是一本详尽的Spring开发指南,覆盖了Spring的核心组件及其应用场景。 - **在线社区**:如Spring Framework论坛和JavaEye论坛,这些社区是解决具体问题的好地方。...

    Spring通过在classpath自动扫描方式把组件纳入spring容器中管理

    7. **配置类和@ComponentScan**: 在Spring 3.0引入的@Configuration注解的类中,可以结合@ComponentScan一起使用,这样就不再需要XML配置文件,实现了全注解配置。 8. **工具支持**: 使用IDE如IntelliJ IDEA或...

    Spring教程

    - **Spring对JavaMail的整合**:通过Spring提供的JavaMailSender接口来简化邮件发送过程。 **10.3 Spring RMI** Spring还支持远程方法调用(RMI): - **Spring RMI**:通过Spring框架支持RMI服务的发布和客户端调用...

    spring2.5 学习笔记

    - **引入 Spring 的 jar 包**:添加 Spring 框架所需的依赖库到项目的 classpath 中。 - **编写测试代码**:编写简单的 Java 类来测试 Spring 是否能够正确加载和使用 Bean。 - **注意接口的使用**:确保所有的 ...

    Spring-Boot-application.properties

    - **默认值**:`classpath:`(即类路径下的文件) - **示例**: ```properties spring.config.location=file:/path/to/config/ ``` 这样配置后,Spring Boot 会从指定的文件系统路径下加载配置文件。 #### 三、...

    Spring中使用classpath加载配置文件浅析

    1. **不使用通配符**:当配置文件路径不包含通配符时,Spring会直接定位到指定的文件。例如: - 当配置文件直接放置在应用的bin目录下的conf文件夹内时,上述代码将加载该目录下的`application-context.xml`文件。...

    mybatis-spring-1.0.2.zip

    MyBatis-Spring 是一个将 MyBatis ORM 框架与 Spring 框架集成的库,使得在 Spring 应用中使用 MyBatis 变得更加方便。mybatis-spring-1.0.2.zip 文件是这个集成库的一个早期版本,适用于 Windows 的不同操作系统。...

Global site tag (gtag.js) - Google Analytics