实现druid数据源密码加密

生成加密密码

集成了druid链接池的,可以实现数据源密码加密。加密方式如下

构建单元测试,并输入密码即可生成加密密码以及加密公钥

复制代码
@Test
public void testPwd() throws Exception {
    String password = "123456";
    String[] arr = com.alibaba.druid.filter.config.ConfigTools.genKeyPair(512);
    System.out.println("privateKey:" + arr[0]);
    System.out.println("publicKey:" + arr[1]);
    System.out.println("password:" + com.alibaba.druid.filter.config.ConfigTools.encrypt(arr[0], password));
}

将生成的 password 和 publickey 记录下来,后面配置中将要使用

springboot项目只需要配置yml文件

复制代码
spring:
  datasource:
    url: ....
    username: user1
    password: ${password}
    type: com.alibaba.druid.pool.DruidDataSource
    druid:
      filters: config,stat,wall,log4j2
      connection-properties: config.decrypt=true;config.decrypt.key=${publicKey}
      ...

配置说明:

  • ${password}: 加密后的密码
  • ${publicKey}: 根据密码生成的公钥
  • filters:config : 配置链接其过滤器 config,用于加密数据库密码

SSM框架项目修改配置文件 properties

复制代码
spring.datasource.password = ${password}
spring.datasource.druid.filters = config,stat,wall,log4j2
spring.datasource.druid.connection-properties = config.decrypt=true;config.decrypt.key=${publicKey}

配置说明:

  • ${password}: 加密后的密码
  • ${publicKey}: 根据密码生成的公钥
  • filters:config : 配置链接其过滤器 config,用于加密数据库密码

验证

直接启动程序,访问数据正常即可。

核心原理介绍

DruidDataSource 链接池在获取链接时会调用一个初始化方法 init:

复制代码
public DruidPooledConnection getConnection(long maxWaitMillis) throws SQLException {
    init(); 
    if (filters.size() > 0) {
        FilterChainImpl filterChain = new FilterChainImpl(this);
        return filterChain.dataSource_connect(this, maxWaitMillis);
    } else {
        return getConnectionDirect(maxWaitMillis);
    }
}

init 方法遍历 filters 列表,并逐个初始化。

在Druid中有一个 ConfigFilter,该 filter 用于对链接池加密、解密处理。

注意事项:filters加上wall配置会严格校验sql格式,--这样的注释不通过会报错

相关推荐
计算机毕设VX:Fegn0895几秒前
计算机毕业设计|基于springboot + vue博物馆展览与服务一体化系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
龙亘川9 分钟前
【课程5.3】功能设计:城管核心指标与设施分布(处置效率、违建数量等指标定义)
数据库·oracle·智慧城市·一网统管ai平台
ybb_ymm15 分钟前
@Async修饰不生效
java·前端·数据库
Psycho_MrZhang23 分钟前
MySQL/PgSQL设计思想总结
数据库·mysql
风吹落叶花飘荡25 分钟前
将mysql数据库的内容备份至阿里云 oss归档存储
数据库·mysql·阿里云
数据大魔方1 小时前
【期货量化入门】期权交易入门:从零开始学期权量化(TqSdk完整教程)
数据库·python·mysql·算法·区块链·程序员创富
虫小宝1 小时前
导购APP高可用数据库设计:主从分离与分库分表在返利系统中的应用
android·数据库
fie88891 小时前
基于蚁群算法求解带时间窗的车辆路径问题
数据库·人工智能·算法
memgLIFE1 小时前
mybatis数据库查询
数据库·oracle·mybatis
闲人不梦卿1 小时前
数据库系统概念
数据库