博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Druid数据库密码加密
阅读量:6540 次
发布时间:2019-06-24

本文共 2391 字,大约阅读时间需要 7 分钟。

1 Druid官方提供的数据库密码加密

1.1执行命令加密数据库密码

在命令行中执行如下命令:

java -cp druid-1.0.16.jar com.alibaba.druid.filter.config.ConfigTools you_password

1.2 配置数据源,提示Druid数据源需要对数据库密码进行解密。

[plain]   
 
  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"  
  2.      init-method="init" destroy-method="close">  
  3.      <property name="url" value="jdbc:derby:memory:spring-test;create=true" />  
  4.      <property name="username" value="sa" />  
  5.      <property name="password" value="${password}" />  
  6.      <property name="filters" value="config" />  
  7.      <property name="connectionProperties" value="config.decrypt=true;config.decrypt.key=${publickey}" />  
  8. </bean>  
 

1.3 配置参数,让ConfigFilter解密密码

有三种方式配置:

1) 可以在配置文件my.properties中指定config.decrypt=true 
2) 也可以在DruidDataSource的ConnectionProperties中指定config.decrypt=true 
3) 也可以在jvm启动参数中指定-Ddruid.config.decrypt=true 

2. 自定义数据库密码加密方法

1. 实现DBPasswordCallback

[java]   
 
  1. package com.netposa.security;  
  2.   
  3. import com.alibaba.druid.util.DruidPasswordCallback;  
  4. import org.apache.commons.lang3.StringUtils;  
  5.   
  6. import java.util.Properties;  
  7.   
  8. /** 
  9.  * Created by Administrator on 2016/11/7. 
  10.  */  
  11. public class DBPasswordCallback extends DruidPasswordCallback {  
  12.     @Override  
  13.     public void setProperties(Properties properties) {  
  14.         super.setProperties(properties);  
  15.         String pwd = properties.getProperty("password");  
  16.         if (StringUtils.isNoneBlank(pwd)) {  
  17.             try {  
  18.                 //这里的password是将jdbc.properties配置得到的密码进行解密之后的值  
  19.                 //所以这里的代码是将密码进行解密  
  20.                 //TODO 将pwd进行解密;  
  21.                 String password = decrypt(pwd);  
  22.                 setPassword(password.toCharArray());  
  23.             } catch (Exception e) {  
  24.                 setPassword(pwd.toCharArray());  
  25.             }  
  26.         }  
  27.     }  
  28.   
  29.     private String decrypt(String src)  
  30.     {  
  31.        //解密  
  32.     }  
  33. }  

2、配置Druid的数据库连接池

  1. <bean id="dbPasswordCallback" class="com.netposa.security.DBPasswordCallback" lazy-init="true"/>  
  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">  
  2.         <property name="driverClassName" value="${datasource.jdbc.driver}"/>  
  3.         <property name="url" value="${datasource.jdbc.url}"/>  
  4.         <property name="username" value="${datasource.jdbc.username}"/>  
  5.         <property name="password" value="${datasource.jdbc.password}"/>  
  6.   
  7.         <property name="passwordCallback" ref="dbPasswordCallback"/>  
  8.         <property name="connectionProperties" value="password=${datasource.jdbc.password}" />  
 
 
 
 
  1. <property name="passwordCallback" ref="dbPasswordCallback"/>  
 
  1. <property name="connectionProperties" value="password=${datasource.jdbc.password}" />  
 
 
  1. ${datasource.jdbc.password}为加密后的密码  
 

转载于:https://www.cnblogs.com/523823-wu/p/9224340.html

你可能感兴趣的文章
29、Java并发性和多线程-非阻塞算法
查看>>
安装OpenResty开发环境
查看>>
第0课 从0开始
查看>>
hadoop无法启动DataNode问题
查看>>
java泛型中<?>和<T>区别
查看>>
这里是指推送通知跟NSNotification有区别:
查看>>
用户ID的代码生成
查看>>
win7经常出现“关闭xxxx前您必须关闭所有会话框”
查看>>
SNMP安全配置的两种方法(也可同一时候兼顾配置两种方法)
查看>>
MongoDB 自己定义函数
查看>>
Summary Day30
查看>>
逆向输出回环数组
查看>>
自己动手,实现“你的名字”滤镜
查看>>
高清摄像头MIPI CSI2接口浅解【转】
查看>>
C# CancellationTokenSource和CancellationToken的实现
查看>>
PCIE BAR空间
查看>>
winform命名规范
查看>>
如何用数学课件制作工具画角平分线
查看>>
VS2015 中统计整个项目的代码行数
查看>>
Anaconda入门使用指南
查看>>