Maven项目中读取src/main/resources目录下的配置文件的方法

在Maven项目的开发中,当需要读取src/下的配置文件时,该怎么做?

创新互联是一家集网站建设,广丰企业网站建设,广丰品牌网站建设,网站定制,广丰网站建设报价,网络营销,网络优化,广丰网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

我们假设Resources下有一个文件名为kafka.properties的配置文件(为什么用kafka.properties,因为这是在做kafka项目的时候碰到的问题,在网上查到了不少信息,索性当个搬运工,再根据自己的理解整理一下)

1.在java类中读取

若配置文件不在src/main/resources目录下,可以直接使用

Properties prop = new properties(); 
prop.load(new InputStream("kafka.properties")); 

当配置文件放在src/main/resources的目录下时,只能使用Class.getResourceAsStream()方法来加载

Properties prop = new properties(); 
prop.load(this.getClass().getResourceAsStream("/kafka.properties")); 

此时,getResourceAsStream(String name)方法中参数路径的写法:

1).若写成"kafka.properties",则是去当前类的class文件同一目录下找(但是显然在正常项目不会有人将配置文件放在这种位置)。

2).若写成"/kafka.properties",则是去整个项目的classes目录下去找,即target/classes

2.在spring框架的xml文件中读取

首先我们先随便写个配置文件kafka.properties

kafka.topic=topic 
serializer.class=kafka.serializer.StringEncoder 
key.serializer.class=kafka.serializer.StringEncoder 

以下就有两种方法来调用

1).首先可以在spring的bean中配置

 
 
 
 /kafka.properties 
 
 
 

这里还可以在list标签中配置多个value,这样就可以在bean中读取一个甚至多个配置文件。

 
   
  ${kafka.topic} 
 

这样就可以在后面的bean中成功调用配置文件中的参数,以上被注释的那段property和被注释掉的那行是同样效果

2).或者也可以使用如下方法

 

直接在spring配置文件中配置context:property-placeholder,有多个配置文件可以用逗号隔开,例如

 

 调用的方法跟1).中一样,这里就不重复了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。


分享标题:Maven项目中读取src/main/resources目录下的配置文件的方法
分享路径:http://hbruida.cn/article/iphgdg.html