Java使用路径通配符加载Resource与profiles配置使用

序言

Spring提供了一种强大的Ant模式通配符匹配,能从一个路径匹配一批资源。

Ant路径通配符

Ant路径通配符支持“?”、“*”、“**”,注意通配符匹配不包括目录分隔符“/”: 

“?”:匹配一个字符,如“config?.xml”将匹配“config1.xml”;

“*”:匹配零个或多个字符串,如“cn/*/config.xml”将匹配“cn/javass/config.xml”,但不匹配匹配“cn/config.xml”;而“cn/config-*.xml”将匹配“cn/config-dao.xml”;

“**”:匹配路径中的零个或多个目录,如“cn/**/config.xml”将匹配“cn /config.xml”,也匹配“cn/javass/spring/config.xml”;而“cn/javass/config-**.xml”将匹配“cn/javass/config-dao.xml”,即把“**”当做两个“*”处理。

classpath和classpath*

Spring在加载类路径资源时除了提供前缀“classpath:”的来支持加载一个Resource,还提供一个前缀“classpath*:”来支持加载所有匹配的类路径Resource。 

一、“classpath”: 用于加载类路径(包括jar包)中的一个且仅一个资源;对于多个匹配的也只返回一个,所以如果需要多个匹配的请考虑“classpath*:”前缀; 

二、“classpath*”: 用于加载类路径(包括jar包)中的所有匹配的资源。带通配符的classpath使用“ClassLoader”的“Enumeration<URLgetResources(String name)”方法来查找通配符之前的资源,然后通过模式匹配来获取匹配的资源。如“classpath:META-INF/*.LIST”将首先加载通配符之前的目录“META-INF”,然后再遍历路径进行子路径匹配从而获取匹配的资源。

classpath用在哪里

在编译打包后的项目中,根目录是META-INFBOOT-INF。这个时候,我们可以看到classes这个文件夹,它就是我们要找的classpath。

这里需要提一点是,此项目可能依赖底层的jar包,比如:api层需要引用dal层的jar包。想说的是所有依赖jar包中的classes是同一级别。

实例助理解:

此代码在api层的jar包中。

此资源是在dal层的jar包中

profiles配置环境配置信息

<profiles>
        <profile>
            <!--prd env-->
            <id>prd</id>
            <properties>
                <profiles.active>prd</profiles.active>
            </properties>
        </profile>
        <profile>
            <!--local env-->
            <id>local</id>
            <properties>
                <profiles.active>local</profiles.active>
            </properties>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
        </profile>
        <profile>
            <!--UT env-->
            <id>ut</id>
            <properties>
                <profiles.active>ut</profiles.active>
            </properties>
        </profile>
        <profile>
            <!-- test env -->
            <id>test</id>
            <properties>
                <profiles.active>test</profiles.active>
            </properties>
        </profile>
    </profiles>

资源文件使用pom文件配置

@xx@圈起来或者${xx},内部是xml链式调用,如下:

激活不同环境需配置profiles.active,也可以在pom文件的profiles中定义,仔细看上面的配置文件<activeByDefault> 节点 local是被设置为激活的

spring.profiles.active=@profiles.active@
project.version=@project.parent.version@

如需正确解析,需在bulid中添加插件

<build>
        <plugins>            
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-resources-plugin</artifactId>
                <version>3.1.0</version>
                <configuration>
                    <!-- 指定配置文件编码 -->
                    <encoding>UTF-8</encoding>
                    <!-- 使用默认分隔符, ${xxx}或者@xxx@ -->
                    <useDefaultDelimiters>true</useDefaultDelimiters>
                </configuration>
            </plugin>
        </plugins>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <filtering>true</filtering>
            </resource>
        </resources>
        <finalName>profit-monitor</finalName>
    </build>

4、激活profile

1)默认的激活

上面的profile配置中设置的默认的激活环境。如下面所示

<activeByDefault>true</activeByDefault> 

2)使用-P参数显示激活一个profile

当我们在进行Maven操作时就可以使用-P参数显示的指定当前激活的是哪一个profile了。比如我们需要在对项目进行打包的时候使用id为dev的profile,我们就可以这样做:

mvn package –Pdev

这里假设dev是在settings.xml中使用dev标记的处于激活状态的profile,那么当我们使用“-P !profile”的时候就表示在当前操作中该profile将不处于激活状态。

总结

java资源加载没完,还有很多吧的,现在没时间,就这些。

posted @ 2019-07-17 10:28  张龙豪  阅读(8152)  评论(1编辑  收藏  举报