谈谈Spring 注入properties文件总结
发布时间 - 2026-01-10 22:47:17 点击率:次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
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】
Laravel如何为API编写文档_Laravel API文档生成与维护方法
Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
如何快速查询域名建站关键信息?
中山网站制作网页,中山新生登记系统登记流程?
香港服务器选型指南:免备案配置与高效建站方案解析
动图在线制作网站有哪些,滑动动图图集怎么做?
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
如何快速搭建高效WAP手机网站?
Java类加载基本过程详细介绍
Laravel DB事务怎么使用_Laravel数据库事务回滚操作
在线制作视频的网站有哪些,电脑如何制作视频短片?
专业商城网站制作公司有哪些,pi商城官网是哪个?
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
Swift中swift中的switch 语句
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
JavaScript如何实现倒计时_时间函数如何精确控制
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
javascript中的try catch异常捕获机制用法分析
Laravel如何使用Telescope进行调试?(安装和使用教程)
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
bootstrap日历插件datetimepicker使用方法
iOS发送验证码倒计时应用
HTML 中如何正确使用模板变量为元素的 name 属性赋值
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
浅谈redis在项目中的应用
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何快速选择适合个人网站的云服务器配置?
如何在云虚拟主机上快速搭建个人网站?
如何在腾讯云服务器上快速搭建个人网站?
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南
如何快速搭建安全的FTP站点?
JS中对数组元素进行增删改移的方法总结
EditPlus中的正则表达式 实战(1)
微信小程序 闭包写法详细介绍
Laravel如何实现用户密码重置功能?(完整流程代码)
HTML5打空格有哪些误区_新手常犯的空格使用错误【技巧】
使用Dockerfile构建java web环境
如何在阿里云购买域名并搭建网站?
教学论文网站制作软件有哪些,写论文用什么软件
?
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
Laravel如何实现一对一模型关联?(Eloquent示例)
Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
如何快速生成ASP一键建站模板并优化安全性?

