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

在Resources下有一个文件名为kafka.properties的配置文件,怎么加载呢,下面整理了一些方法和说明。

一、在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)方法中参数路径的写法:

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

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

二、在spring框架的xml文件中读取

// 配置文件kafka.properties
kafka.topic=topic
serializer.class=kafka.serializer.StringEncoder
key.serializer.class=kafka.serializer.StringEncoder
  • 首先可以在spring的bean中配置
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  <property name="locations">
    <list>
      <value>/kafka.properties</value>
    </list>
  </property>
</bean>

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

<bean id="kafkaService" class="com.wws.service.impl.KafkaServiceImpl">
    <!-- <property name="topic"><value>topic</value></property> -->
    <property name="topic"><value>${kafka.topic}</value></property>
</bean>

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

  • 或者也可以使用如下方法
<context:property-placeholder location="classpath:kafka.properties"/>

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

<context:property-placeholder location="classpath:kafka.properties,classpath:jdbc.properties"/>

调用的方法跟上面一样,这里就不赘述了。

Scala语言 & 开发

scala语言学习(六)、scala面向对象编程类、对象、继承、trait特质

2020-7-13 1:06:37

Scala语言 & 开发

scala语言学习(七)、scala模式匹配和以及scala样例类

2020-7-17 0:34:21

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
购物车
优惠劵
搜索