Druid集成Springboot修改自定义密码加密配置
Springboot自带一种对配置文件密码的加密方式,使用ConfigTools进行设置,ENC的使用,这种模式需要定义salt并根据配置文件可自行解密,如果有自定义加密方式无法使用,Druid原生支持自行实现加解密,只需要实现解密类,然后配置对应解密类即可,首先编写类继承DruidPasswordCallback,在setProperties方法中解密密码
下面展示一些 代码片。
public class DBPasswordCallback extends DruidPasswordCallback {
@Override
public void setProperties(Properties properties) {
super.setProperties(properties);
//获取配置文件中的已经加密的密码
String pwd = (String)properties.get("password");
if (StringUtil.isNotEmpty(pwd)) {
try {
//这里的代码是将密码进行解密,并设置
String password = AesUtil.decryptForString(pwd);
setPassword(password.toCharArray());
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
该代码编辑完成后,还需要在application.yml中配置解密的类,具体添加配置如下:
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driverClassName: com.mysql.cj.jdbc.Driver
druid:
# 主库数据源
master:
url: jdbc:mysql:?
username:
password:
connection-properties: password=${spring.datasource.druid.master.password}
password-callback-class-name: com.xx.xx.xx.DBPasswordCallback
至此加密规则可以自己定义了。
本文介绍了如何在Springboot集成Druid时,修改默认的密码加密方式。通过创建自定义解密类,继承DruidPasswordCallback,并在setProperties方法中处理解密过程。此外,还需在application.yml配置文件中指定自定义的解密类,以实现自定义加密规则。

1217

被折叠的 条评论
为什么被折叠?



