在spirng容器装配dataSource的属性时,获取jdbc配置文件中对应的值,先解密

本文介绍如何在Spring中配置加密的数据库连接属性,并通过扩展PropertyPlaceholderConfigurer实现解密过程,确保数据库敏感信息的安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

       jdbc.properties配置文件中的信息(用户名、用户密码、url)是经过加密的,然后放在系统的WEB-INF文件夹下供系统使用。由于这些信息是加密的,系统将数据库连接交给了spring管理,所以在spring初始化datasource-bean装配这些属性对应的值时,必须先解密。

 

<!--修改前spirng的配置文件:-->
<bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
	<property name="locations">
	<list>
	<value>classpath:jdbc.properties</value>
	</list>
	</property>
</bean>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
	<property name="driverClass" value="${driverClass}"></property>
	<property name="jdbcUrl" value="${jdbcUrl}"></property>
	<property name="user" value="${username}"></property>
	<property name="password" value="${password}"></property>
	<property name="initialPoolSize" value="${initialPoolSize}"></property>
	<property name="maxPoolSize" value="${maxPoolSize}"></property>
	<property name="minPoolSize" value="${minPoolSize}"></property>
	<property name="acquireIncrement" value="${acquireIncrement}"></property>
	<property name="checkoutTimeout" value="${checkoutTimeout}"></property>
	<property name="acquireRetryAttempts" value="${acquireRetryAttempts}"></property>
</bean>

 

//org.springframework.beans.factory.config.PropertyPlaceholderConfi//gurer这个类是用来从指定的配置文件中取值,替换bean中的${}。我们现在要
//做的是,在从指定的配置文件中取出值返回时,对该值进行解密,再返回。对该
//类进行扩展,代码如下:

import java.util.Properties;

import org.springframework.beans.factory.config.PropertyPlaceholderConfigurer;

public class MyPropertyPlaceholderConfigurer extends
		PropertyPlaceholderConfigurer {
	
	
	@Override
	protected String resolvePlaceholder(String placeholder, Properties props) {
		String val = props.getProperty(placeholder);
		if(placeholder.equals("jdbcUrl") || placeholder.equals("username") || placeholder.equals("password")) {
			String result = DESDecrypt.execDecrypt(val);
		    return result;
		} else {
			return val;
		}
		 
	}
}

 

<!-- 修改后的spirng配置文件 -->
<bean class="cn.com.jit.pki.util.MyPropertyPlaceholderConfigurer">
	<property name="locations">
	<list>
	<value>classpath:jdbc.properties</value>
	</list>
	</property>
</bean>
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
	<property name="driverClass" value="${driverClass}"></property>
	<property name="jdbcUrl" value="${jdbcUrl}"></property>
	<property name="user" value="${username}"></property>
	<property name="password" value="${password}"></property>
	<property name="initialPoolSize" value="${initialPoolSize}"></property>
	<property name="maxPoolSize" value="${maxPoolSize}"></property>
	<property name="minPoolSize" value="${minPoolSize}"></property>
	<property name="acquireIncrement" value="${acquireIncrement}"></property>
	<property name="checkoutTimeout" value="${checkoutTimeout}"></property>
	<property name="acquireRetryAttempts" value="${acquireRetryAttempts}"></property>
</bean>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值