java maven项目如何读取配置文件信息

网友投稿 413 2022-11-21

java maven项目如何读取配置文件信息

目录maven项目读取配置文件信息主类配置文件pom文件控制台运行jar命令运行maven工程读取resources配置文件的姿势maven项目结构如下

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文件

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

com.tomy.hive

hive-demo

1.0-SNAPSHOT

hive-demo

http://example.com

UTF-8

1.8

1.8

junit

junit

4.11

test

org.apache.maven.plugins

maven-surefire-plugin

true

org.apache.maven.plugins

maven-jar-plugin

3.0.2

true

com.tomy.hive.App

maven-resources-plugin

copy-resources

validate

copy-resources

${project.build.directory}/conf

src/main/resources

true

src/main/resources

**/**.properties

/resources

xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

4.0.0

com.tomy.hive

hive-demo

1.0-SNAPSHOT

hive-demo

http://example.com

UTF-8

1.8

1.8

junit

junit

4.11

test

org.apache.maven.plugins

maven-surefire-plugin

true

org.apache.maven.plugins

maven-jar-plugin

3.0.2

true

com.tomy.hive.App

maven-resources-plugin

copy-resources

validate

copy-resources

${project.build.directory}/conf

src/main/resources

true

src/main/resources

**/**.properties

/resources

控制台运行

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包运行都能正常读取到配置文件了。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Hadoop中mapreduce作业日志是如何生成的
下一篇:Windows7成功安装Flume 1.7!
相关文章

 发表评论

暂时没有评论,来抢沙发吧~