c3p0 数据源密码加密
c3p0 数据源密码加密
晚点回家 发表于3个月前
c3p0 数据源密码加密
  • 发表于 3个月前
  • 阅读 0
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 十分钟定制你的第一个小程序>>>   

application-context.xml  数据源配置 

需要注意的是: <property name="properties" ref="dataSourceProperties"/> 需要写在最前面  不然可能会出现密码错误等问题

bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
        <property name="properties" ref="dataSourceProperties"/>
        <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="autoCommitOnClose" value="true"/>
        <property name="checkoutTimeout" value="${cpool.checkoutTimeout}"/>
        <property name="initialPoolSize" value="${cpool.minPoolSize}"/>
        <property name="minPoolSize" value="${cpool.minPoolSize}"/>
        <property name="maxPoolSize" value="${cpool.maxPoolSize}"/>
        <property name="maxIdleTime" value="${cpool.maxIdleTime}"/>
        <property name="acquireIncrement" value="${cpool.acquireIncrement}"/>
        <property name="maxIdleTimeExcessConnections" value="${cpool.maxIdleTimeExcessConnections}"/>
    </bean>
    <bean id="dataSourceProperties" class="com.ezsite.doc.PropertiesEncryptFactoryBean">  
        <property name="properties">  
            <props>  
                <prop key="user">加密后的用户名</prop>  
                <prop key="password">加密后的密码</prop>  
            </props>  
        </property>  
    </bean>

实现类

需要实现FactoryBean  否则会报数据类型错误

package com.ezsite.doc;

import java.util.Properties;

import org.apache.commons.codec.binary.Base64;
import org.springframework.beans.factory.FactoryBean;

import sun.misc.BASE64Decoder;

public class PropertiesEncryptFactoryBean implements FactoryBean{
	
	private Properties properties;  
    
    public Object getObject() throws Exception {  
        return getProperties();  
    }  
  
    public Class getObjectType() {  
        return java.util.Properties.class;  
    }  
  
    public boolean isSingleton() {  
        return true;  
    }  
  
    public Properties getProperties() {  
        return properties;  
    }  
  
    public void setProperties(Properties inProperties) {  
        this.properties = inProperties;  
        String originalUsername = properties.getProperty("user");  
        String originalPassword = properties.getProperty("password");  
        if (originalUsername != null){  
            String newUsername = deEncryptPassword(originalUsername );  
            properties.put("user", newUsername);  
        }  
        if (originalPassword != null){  
            String newPassword = deEncryptPassword(originalPassword);  
            properties.put("password", newPassword);  
        }  
    }  
      
    private String deEncryptPassword(String originalPassword){  
        return deEncryptString(originalPassword);  
    }  
    //相关解密操作
    private  String deEncryptString(String originalString){  
    	 
		return originalString;    
    }  
}

转载地址:http://xinklabi.iteye.com/blog/2173220

共有 人打赏支持
粉丝 0
博文 3
码字总数 1485
×
晚点回家
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: