spring提供了多种方式来注入properties文件,本文做一个简单的总结。

在Spring配置文件中引入
方式一
通过<context:property-placeholder />标签
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<context:property-placeholder location="classpath:mysql.properties" ignore-unresolvable="true"/>
<!-- 配置数据源 -->
<bean abstract="true" name="parentDatasource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${ds1.jdbc.driverClassName}" />
<!-- 初始化连接大小 -->
<property name="initialSize" value="1" />
<!-- 连接池最大使用连接数量 -->
<property name="maxActive" value="100" />
<!-- 连接池最小空闲 -->
<property name="minIdle" value="20" />
<!-- 获取连接最大等待时间 -->
<property name="maxWait" value="30000" />
<!-- <property name="poolPreparedStatements" value="true" /> -->
<!-- <property name="maxPoolPreparedStatementPerConnectionSize" value="33" /> -->
<property name="validationQuery" value="SELECT 1" />
<property name="testOnBorrow" value="true" />
<property name="testOnReturn" value="true" />
<property name="testWhileIdle" value="true" />
<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
<property name="timeBetweenEvictionRunsMillis" value="60000" />
<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
<property name="minEvictableIdleTimeMillis" value="25200000" />
<!-- 打开removeAbandoned功能 -->
<property name="removeAbandoned" value="true" />
<!-- 1800秒,也就是30分钟 -->
<property name="removeAbandonedTimeout" value="1800" />
<!-- 关闭abanded连接时输出错误日志 -->
<property name="logAbandoned" value="true" />
<!-- 监控数据库 -->
<!-- <property name="filters" value="stat" /> -->
<property name="filters" value="mergeStat" />
</bean>
<!-- 配置数据源 -->
<bean name="dataSource1" init-method="init" destroy-method="close" parent="parentDatasource">
<property name="url" value="${ds1.jdbc.url}" />
<property name="username" value="${ds1.jdbc.username}" />
<property name="password" value="${ds1.jdbc.password}" />
</bean>
<!-- 配置数据源 -->
<bean name="dataSource2" init-method="init" destroy-method="close" parent="parentDatasource">
<property name="url" value="${ds2.jdbc.url}" />
<property name="username" value="${ds2.jdbc.username}" />
<property name="password" value="${ds2.jdbc.password}" />
</bean>
<!-- 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource1" />
</bean>
<!-- 注解方式配置事物 -->
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>
方式二
通过<util:properties />
1、MySQL.properties
# ds1.jdbc.driverClassName=com.mysql.jdbc.Driver ds1.jdbc.url=jdbc:mysql://localhost:3306/process?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull ds1.jdbc.username=root ds1.jdbc.password=root ds2.jdbc.driverClassName=com.mysql.jdbc.Driver ds2.jdbc.url=jdbc:mysql://localhost:3306/process?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull ds2.jdbc.username=root ds2.jdbc.password=root
2、applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:jee="http://www.springframework.org/schema/jee" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:task="http://www.springframework.org/schema/task" xmlns:util="http://www.springframework.org/schema/util" xmlns:jaxws="http://cxf.apache.org/jaxws"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/util
http://www.springframework.org/schema/util/spring-util.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd"
default-lazy-init="false">
<util:properties id="db" location="classpath:mysql.properties"/>
<!-- 配置数据源 -->
<bean name="dataSource1" init-method="init" destroy-method="close" parent="parentDatasource">
<property name="url" value="#{db['ds1.jdbc.url']}" />
<property name="username" value="#{db['ds1.jdbc.username']}" />
<property name="password" value="#{db['ds1.jdbc.password']}" />
</bean>
</beans>
在代码中注入
方式一
1、config.properties
name=ricky age=27 password=root
2、applicationContext.xml
<!-- 使用注解注入properties中的值 -->
<bean id="config"
class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="locations">
<list>
<value>classpath:config.properties</value>
</list>
</property>
<!-- 设置编码格式 -->
<property name="fileEncoding" value="UTF-8"></property>
</bean>
3、使用@Value注解
package com.ricky.codelab.springmvc.domain;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
/**
* ${DESCRIPTION}
*
* @author Ricky Fung
* @create 2016-08-08 15:49
*/
@Component("userService")
public class UserServiceImpl implements IUserService {
private final Logger logger = LoggerFactory.getLogger(getClass());
@Value("#{config[name]}")
private String name;
@Value("#{config[age]}")
private Integer age;
@Value("#{config[password]}")
private String password;
@Override
public void login(String username){
System.out.println("name:"+name+",age="+age+",password="+password);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# spring注入properties
# 注解注入properties
# spring
# properties
# 在SpringBoot下读取自定义properties配置文件的方法
# SpringBoot获取yml和properties配置文件的内容
# 详解Spring Boot加载properties和yml配置文件
# 详解SpringMVC加载配置Properties文件的几种方式
# 详解spring boot 使用application.properties 进行外部配置
# Spring Boot中配置文件application.properties使用
# Spring Boot2.0 @ConfigurationProperties使用详解
# spring boot使用i18n时properties文件中文乱码问题的解决方法
# Spring加载properties文件的方法
# Spring中配置和读取多个Properties文件的方式方法
# 详解Spring加载Properties配置文件的四种方式
# Spring中属性文件properties的读取与使用详解
# spring boot application properties配置实例代码详解
# Spring Boot的properties配置文件读取
# spring boot中的properties参数配置详解
# Spring用代码来读取properties文件实例解析
# Spring加载properties文件的两种方式实例详解
# spring无法读取properties文件数据问题详解
# 连接池
# 做一个
# 管理器
# 配置文件
# 大家多多
# 池中
# 多久
# maxWait
# minIdle
# validationQuery
# poolPreparedStatements
# maxPoolPreparedStatementPerConnectionSize
# jdbc
# driverClassName
# pool
# DruidDataSource
# maxActive
# alibaba
# druid
# initialSize
相关文章:
家庭建站与云服务器建站,如何选择更优?
如何挑选优质建站一级代理提升网站排名?
linux top下的 minerd 木马清除方法
建站之星安装模板失败:服务器环境不兼容?
建站之星后台密码遗忘?如何快速找回?
如何快速搭建高效可靠的建站解决方案?
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
如何在IIS中新建站点并配置端口与IP地址?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
如何通过PHP快速构建高效问答网站功能?
如何用PHP快速搭建高效网站?分步指南
香港服务器建站指南:免备案优势与SEO优化技巧全解析
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
如何在阿里云完成域名注册与建站?
详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)
音响网站制作视频教程,隆霸音响官方网站?
javascript中对象的定义、使用以及对象和原型链操作小结
建站之星安装后界面空白如何解决?
如何在服务器上三步完成建站并提升流量?
如何选择美橙互联多站合一建站方案?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
免费网站制作appp,免费制作app哪个平台好?
如何用IIS7快速搭建并优化网站站点?
建站主机空间推荐 高性价比配置与快速部署方案解析
建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析
如何通过多用户协作模板快速搭建高效企业网站?
如何用景安虚拟主机手机版绑定域名建站?
创业网站制作流程,创业网站可靠吗?
宝塔建站助手安装配置与建站模板使用全流程解析
建站之星logo尺寸如何设置最合适?
宝塔新建站点报错如何解决?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
如何设计高效校园网站?
如何通过商城免费建站系统源码自定义网站主题?
如何快速查询域名建站关键信息?
建站之星展会模版如何一键下载生成?
如何选择高效稳定的ISP建站解决方案?
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
css网站制作参考文献有哪些,易聊怎么注册?
专业网站制作服务公司,有哪些网站可以免费发布招聘信息?
广平建站公司哪家专业可靠?如何选择?
北京专业网站制作设计师招聘,北京白云观官方网站?
如何在阿里云部署织梦网站?
长沙做网站要多少钱,长沙国安网络怎么样?
C#如何序列化对象为XML XmlSerializer用法
宝塔Windows建站如何避免显示默认IIS页面?
如何通过山东自助建站平台快速注册域名?
制作网站的模板软件,网站怎么建设?
如何制作网站标识牌,动态网站如何制作(教程)?
*请认真填写需求信息,我们会在24小时内与您取得联系。