文档章节

Spring 如何读取properties文件内容

binhu
 binhu
发布于 2015/01/21 14:23
字数 737
阅读 110
收藏 0

Spring中config属性文件的读取与使用 PropertyPlaceholderConfigurer 注解@Component

1.配置文件:/WEB-INF/configInfo.properties
配置文件内容:
email.host = www.94gleaner.com
email.port = xxx
email.username = gleaner
email.password = xxx
email.sendFrom = 94gleaner@94gleaner.com

2.Spring容器启动时,使用内置bean对属性文件信息进行加载,在bean.xml中添加如下:

<!– spring的属性加载器,加载properties文件中的属性   方案①-->
<bean id=”propertyConfigurer” class=”org.springframework.beans.factory.config.PropertyPlaceholderConfigurer”>
property name=”location”>
<value>/WEB-INF/configInfo.properties</value>
</property>
<property name=”fileEncoding” value=”utf-8″ />
</bean>

<!--或者通过如下方式加载       方案②-->
<context:property-placeholder location="classpath:ldap.properties" ignore-unresolvable="true"/>



    <!-- 将多个配置文件读取到容器中,交给Spring管理 -->  
    <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
        <property name="locations">  
           <list>  
              <!-- 这里支持多种寻址方式:classpath和file -->  
              <value>classpath:/opt/demo/config/demo-db.properties</value>  
              <!-- 推荐使用file的方式引入,这样可以将配置和代码分离 -->  
              <value>file:/opt/demo/config/demo-mq.properties</value>  
              <value>file:/opt/demo/config/demo-remote.properties</value>  
            </list>  
        </property>  
    </bean>

3.其它bean中引用,例:

<property name="host">
       <value>${email.host}</value>
</property>
<property name=”port”>
       <value>${email.port}</value>
</property>

4.JAVA代码中获取方法:创建ConfigInfo.java

@Component("configInfo")
public class ConfigInfo {
@Value("${email.host}")
private String host;
@Value("${email.port}")
private String port;
public String getHost() {
return host;
}
public String getPort() {
return port;
}
}

5.代码中调用

@Autowired
private ConfigInfo configInfo;
public byte[] Test(HttpServletResponse response) {
string host = configInfo.getHost();
}

 

 

 

config.properties配置文件信息

Properties代码  收藏代码

##数据库(mysql|mssql|oracle...)  

environment=mysql  

jdbc.driver=com.mysql.jdbc.Driver  

jdbc.url=jdbc:mysql://127.0.0.1:3306/portal?useUnicode=true&characterEncoding=utf8  

jdbc.user=root  

jdbc.password=root  

#初始化连接(根据实际访问量设置大小)  

jdbc.initialSize=10  

#最大空闲连接(根据实际访问量设置大小)  

jdbc.maxIdle=50  

#最小空闲连接(根据实际访问量设置大小)  

jdbc.minIdle=10  

#最大连接数量(根据实际访问量设置大小)  

jdbc.maxActive=200  

 Spring配置信息(截取部分)

Xml代码  收藏代码

<context:property-placeholder location="classpath:config.properties" />  

  <!--创建jdbc数据源 -->  

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  

  <property name="driverClassName" value="${jdbc.driver}"/>  

 <property name="url" value="${jdbc.url}"/>  

<property name="username" value="${jdbc.user}"/>  

 <property name="password" value="${jdbc.password}"/>  

 <property name="initialSize" value="${jdbc.initialSize}"/>  

<property name="maxIdle" value="${jdbc.maxIdle}"/>  

 <property name="minIdle" value="${jdbc.minIdle}"/>  

<property name="maxActive" value="${jdbc.maxActive}"/>  

 <property name="removeAbandoned" value="true"/>    

  <property name="removeAbandonedTimeout" value="120"/>  

  <property name="maxWait" value="3000"/>  

</bean>  

<!-- 创建SqlSessionFactory,同时指定数据源 -->  

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  

   <property name="dataSource" ref="dataSource"/>  

  <property name="configLocation" value="classpath:mybatis-config.xml"/>  

  <property name="mapperLocations" value="classpath*:com.anly.portal.*.mapper/*Mapper.xml" />   

</bean>  

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">  

  <!-- 此处扫描的是Mapper接口 -->  

 <property name="basePackage" value="com.anly.portal.*.mapper"/>  

<property name="sqlSessionFactory" ref="sqlSessionFactory"/>  

</bean>  

 此时,启动会报异常,${jdbc.driver}这样的表达式获取不到properties里面的值,因为MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了,解决的办法如下:

 

方法一:

修改<property name="sqlSessionFactory" ref="sqlSessionFactory"/>为<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>

原理:使用sqlSessionFactoryBeanName注入,不会立即初始化sqlSessionFactory, 所以不会引发提前初始化问题。

 

方法二:

直接删掉<property name="sqlSessionFactory" ref="sqlSessionFactory"/>

注意:在没有配置这一行时,必须配置一个以sqlSessionFactory命名的org.mybatis.spring.SqlSessionFactoryBean。

© 著作权归作者所有

共有 人打赏支持
binhu
粉丝 17
博文 209
码字总数 205648
作品 0
合肥
如何在spring中读取properties配置文件里面的信息

如何在spring中读取properties配置文件里面的信息 <!-- 正文开始 --> 一般来说。我们会将一些配置的信息放在。properties文件中。 然后使用${}将配置文件中的信息读取至spring的配置文件。 ...

巴顿
2014/04/24
0
0
SpringBoot基础篇配置信息之如何读取配置信息

更多Spring文章,欢迎点击 一灰灰Blog-Spring专题 SpringBoot极大的减少了配置,开一个新项目时,完全可以做到什么配置都不加,就可以直接跑,简单方便的同时,就带来了一个问题 怎么知道这些...

小灰灰Blog
10/14
0
0
微服务 SpringBoot 2.0(二):配置文件解析

properties我用了好多年,你却让我用yml,这是什么鬼 —— Java面试必修 引言 上一篇介绍了Spring Boot的轻松入门项目构建,对Spring Boot的特性有了初步了解。但如果要想玩得很熟练的话就请...

阿郎_
09/23
0
0
java读取Properties属性文件的方法

Properties属性文件在JAVA应用程序中是经常可以看得见的,也是特别重要的一类文件,用来配置应用程序的一些信息,通过键值对的形式来保存。 一、通过spring的形式读取 1、spring配置文件: ...

南的糊途
2013/03/13
0
0
SpringBoot基础篇配置信息之自定义配置指定与配置内引用

更多Spring文章,欢迎点击 一灰灰Blog-Spring专题 前面两篇文章,分别介绍了如何获取配置信息,区分多环境的配置支持,配置信息的优先级问题,那么掌握这些是否就足够了呢? 如何获取指定文件...

小灰灰Blog
10/14
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Hbase Schema 模型设计注意事项及示例

一、Hbase 数据模型概述 HBase的数据模型也是由表组成,每一张表里也有数据行和列,但是在HBase数据库中的行和列又和关系型数据库的稍有不同。 表(Table): HBase会将数据组织成一张表,表名必...

PeakFang-BOK
40分钟前
1
0
Blockathon(2018)上海竞赛项目成果今天揭晓

开幕式现场 10月19日,Blockathon(2018)上海在黄浦区P2联合创业办公社举行,本次活动由50名区块链开发者组成9支参赛队伍,来自国内外优秀区块链开发团队的20名技术专家担任导师及裁判。9支队...

HiBlock
43分钟前
0
0
微信小程序开发系列六:微信框架API的调用

微信小程序开发系列教程 微信小程序开发系列一:微信小程序的申请和开发环境的搭建 微信小程序开发系列二:微信小程序的视图设计 微信小程序开发系列三:微信小程序的调试方法 微信小程序开发...

JerryWang_SAP
今天
4
0
5 个用 Python 编写 web 爬虫的方法

大家在读爬虫系列的帖子时常常问我怎样写出不阻塞的爬虫,这很难,但可行。通过实现一些小策略可以让你的网页爬虫活得更久。那么今天我就将和大家讨论这方面的话题。 我刚整理了一套2018最新...

糖宝lsh
今天
6
0
docker安装redis、mongodb、mysql等

一、启动docker服务,设置镜像: systemctl start dockervi /etc/docker/daemon.json{ "registry-mirrors": ["https://registry.docker-cn.com"]} 二、下拉镜像: 在镜像中心h...

狼王黄师傅
今天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部