生产环境c3p0数据源用户名密码加密或解密

直接上代码,相信大部分人能看懂

Spring applicationContext.xml

 <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">
        <property name="properties">  
          <bean class="cn.oa.util.C3P0DatasourcePropertiesFactory" factory-method="getProperties">
                <constructor-arg type="java.lang.String">
                    <value>${jdbc.password}</value>
                </constructor-arg>
                <!-- 生产环境模式 ,才特殊处理加密密码-->  
                <constructor-arg type="java.lang.String">
                    <value>${jdbc.password.encrypted}</value>
                </constructor-arg>
        	</bean>
   		</property>
        <property name="driverClass" value="${jdbc.driverClassName}"/>
        <property name="jdbcUrl" value="${jdbc.url}"/>
        <property name="user" value="${jdbc.userName}"/>
        <!-- <property name="password" value="${jdbc.password}"/> -->
       	<property name="initialPoolSize" value="10"/>
        <property name="maxPoolSize" value="${db.pool.maxpoolsize}"/>
        <property name="minPoolSize" value="${db.pool.minpoolsize}"/>
        <property name="acquireIncrement" value="5"/>  <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。 -->
        
        <property name="idleConnectionTestPeriod" value="60"/><!--每30秒检查所有连接池中的空闲连接。--> 
    </bean>

注意,这里有个先后顺序的问题, <property name="properties"> 必须要在前面


import java.util.Properties;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import cn.biznest.mediacircle.util.encrypt.CryptoUtil;

public class C3P0DatasourcePropertiesFactory {
	private static final String PRODUCTION_MODE = "true";
	private static final String PROP_PASSWORD = "password";
	private final static Logger logger = LoggerFactory.getLogger(C3P0DatasourcePropertiesFactory.class);

	public static Properties getProperties(String pwd, String production) throws Exception {
		Properties p = new Properties();

		if (PRODUCTION_MODE.equals(production)) {
			try {
				p.setProperty(PROP_PASSWORD, CryptoUtil.decode(pwd));//解密操作
			 catch (Exception e) {
				logger.error("C3P0DatasourcePropertiesFactory getProperties is error!", e);
				throw e;
			}
		}else{
			p.setProperty(PROP_PASSWORD, pwd);
		}
		return p;
	}
}


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值