java maven项目如何读取配置文件信息
程序员文章站
2022-06-17 23:43:26
目录maven项目读取配置文件信息主类配置文件pom文件控制台运行jar命令运行maven工程读取resources配置文件的正确姿势maven项目读取配置文件信息目录结构主类app.javapack...
maven项目读取配置文件信息
目录结构
主类
app.java
package com.tomy.hive; import java.io.*; import java.util.properties; /** * hello world! * */ public class app { private static string jdbc_url; private static string jdbc_driver; /** * 读取配置文件 * @return */ public static void readconfigfile(string cfgfile) { try { inputstream in = app.class.getclassloader().getresource(cfgfile).openstream(); properties prop = new properties(); prop.load(in); jdbc_url = prop.getproperty("jdbc.url"); jdbc_driver = prop.getproperty("jdbc.driver"); } catch (ioexception e) { e.printstacktrace(); } } public static void main(string[] args) { readconfigfile("resources/jdbc.properties"); system.out.println(jdbc_url); system.out.println(jdbc_driver); } }
配置文件
jdbc.properties
jdbc.url=jdbc:mysql://10.6.52.35:3306/test?characterencoding=utf-8&servertimezone=utc&usessl=false jdbc.driver=com.mysql.jdbc.driver
pom文件
<?xml version="1.0" encoding="utf-8"?> <project xmlns="http://maven.apache.org/pom/4.0.0" xmlns:xsi="http://www.w3.org/2001/xmlschema-instance" xsi:schemalocation="http://maven.apache.org/pom/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelversion>4.0.0</modelversion> <groupid>com.tomy.hive</groupid> <artifactid>hive-demo</artifactid> <version>1.0-snapshot</version> <name>hive-demo</name> <!-- fixme change it to the project's website --> <url>http://www.example.com</url> <properties> <project.build.sourceencoding>utf-8</project.build.sourceencoding> <maven.compiler.source>1.8</maven.compiler.source> <maven.compiler.target>1.8</maven.compiler.target> </properties> <dependencies> <dependency> <groupid>junit</groupid> <artifactid>junit</artifactid> <version>4.11</version> <scope>test</scope> </dependency> </dependencies> <build> <pluginmanagement><!-- lock down plugins versions to avoid using maven defaults (may be moved to parent pom) --> <plugins> <plugin> <groupid>org.apache.maven.plugins</groupid> <artifactid>maven-surefire-plugin</artifactid> <configuration> <skip>true</skip> </configuration> </plugin> <plugin> <groupid>org.apache.maven.plugins</groupid> <artifactid>maven-jar-plugin</artifactid> <version>3.0.2</version> <configuration> <archive> <manifest> <addclasspath>true</addclasspath> <mainclass>com.tomy.hive.app</mainclass> </manifest> </archive> </configuration> </plugin> <plugin> <artifactid>maven-resources-plugin</artifactid> <executions> <execution> <id>copy-resources</id> <phase>validate</phase> <goals> <goal>copy-resources</goal> </goals> <configuration> <outputdirectory>${project.build.directory}/conf</outputdirectory> <resources> <resource> <directory>src/main/resources</directory> </resource> </resources> </configuration> </execution> </executions> </plugin> </plugins> </pluginmanagement> <resources> <resource> <filtering>true</filtering> <directory>src/main/resources</directory> <includes> <include>**/**.properties</include> </includes> <targetpath>/resources</targetpath> </resource> </resources> </build> </project>
控制台运行
jar命令运行
maven工程读取resources配置文件的正确姿势
我们maven项目结构如下:
使用相对路径来读取resources目录下的资源文件
inputstream in = new inputstream(new file(“src/main/resources/car.txt”));
这样在本地运行的时候,是能正常读取到的,不会报错,但是如果打成jar包,运行的时候就会报路径错误。
从jar包的结构可以看到,resources目录的资源文件位置变了,在项目的最外层了,所以导致相对路径也发生了变化。
这个时候,我们可以通过getclassloader()方法来获取正确的配置文件路径。
(this也可以换成类的名称)
inputstream in = this.class.getclassloader().getresourceasstream(path);
这样,在本地运行或者jar包运行都能正常读取到配置文件了。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
上一篇: Python性能调优的十个小技巧总结
下一篇: 浅谈Django Admin的初步使用