springboot 使用druid 配置数据库密码加密

news/2025/11/12 10:26:24/文章来源:https://www.cnblogs.com/zhncnblogs/p/19212743

springboot 使用druid 配置数据库密码加密

springboot 使用druid 配置数据库密码加密
1.添加DruidConfig配置类

package org.jeecg.config;import com.alibaba.druid.filter.config.ConfigTools;
import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.support.http.StatViewServlet;
import com.alibaba.druid.support.http.WebStatFilter;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.web.servlet.FilterRegistrationBean;
import org.springframework.boot.web.servlet.ServletRegistrationBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;import javax.sql.DataSource;
import java.sql.SQLException;/*** Druid配置类* 1、可以监控数据库访问性能,内置了插件:StatFilter,能够详细统计SQL执行性能,用于线上分析数据库访问性能。* 2、替换DBCP、C3P0数据库连接池,提供了一个高效稳定的扩展性能好的数据库连接池DruidDataSource。* 3、数据库加密,DruidDriuiver和DruidDataSource都支持PasswordCallback。* 4、SQL执行日志。* 5、扩展JDBC,如果你要对JDBC层有编程的需求,可以通过Druid提供的Filter-Chain机制,很方便编写JDBC层的扩展插件* Druid是一个阿里开源的数据库连接池框架,有可视化界面。* http://localhost:8080/druid/login.html* 可以查看sql访问速度等等很多信息,感觉还是比较有用的。集成进来试试* @author maybe*/
@Configuration
@Slf4j
public class DruidConfig {//使用@value注入配置文件中信息@Value("${spring.datasource.dynamic.datasource.master.url}")private String dbUrl;@Value("${spring.datasource.dynamic.datasource.master.username}")private String username;@Value("${spring.datasource.dynamic.datasource.master.password}")private String password;@Value("${spring.datasource.dynamic.datasource.master.public-key}")private String publicKey;@Value("${spring.datasource.dynamic.datasource.master.driver-class-name}")private String driverClassName;@Value("${spring.datasource.dynamic.druid.initial-size}")private int initialSize;@Value("${spring.datasource.dynamic.druid.min-idle}")private int minIdle;@Value("${spring.datasource.dynamic.druid.max-active}")private int maxActive;@Value("${spring.datasource.dynamic.druid.max-wait}")private int maxWait;@Value("${spring.datasource.dynamic.druid.timeBetweenEvictionRunsMillis}")private int timeBetweenEvictionRunsMillis;@Value("${spring.datasource.dynamic.druid.minEvictableIdleTimeMillis}")private int minEvictableIdleTimeMillis;@Value("${spring.datasource.dynamic.druid.validationQuery}")private String validationQuery;@Value("${spring.datasource.dynamic.druid.testWhileIdle}")private boolean testWhileIdle;@Value("${spring.datasource.dynamic.druid.testOnBorrow}")private boolean testOnBorrow;@Value("${spring.datasource.dynamic.druid.testOnReturn}")private boolean testOnReturn;@Value("${spring.datasource.dynamic.druid.filters}")private String filters;@Value("${spring.datasource.dynamic.druid.logSlowSql}")private String logSlowSql;@Value("${spring.datasource.dynamic.druid.connectionProperties}")private String connectionProperties;@Beanpublic ServletRegistrationBean druidServlet() throws Exception {ServletRegistrationBean reg = new ServletRegistrationBean();reg.setServlet(new StatViewServlet());reg.addUrlMappings("/druid/*");//配置访问URLreg.addInitParameter("loginUsername", username);  //配置用户名,这里使用数据库账号。reg.addInitParameter("loginPassword", ConfigTools.decrypt(publicKey,password));  //配置用户名,这里使用数据库密码reg.addInitParameter("logSlowSql", logSlowSql);   //是否启用慢sqlreturn reg;}@Beanpublic FilterRegistrationBean filterRegistrationBean() {FilterRegistrationBean filterRegistrationBean = new FilterRegistrationBean();filterRegistrationBean.setFilter(new WebStatFilter());filterRegistrationBean.addUrlPatterns("/*");filterRegistrationBean.addInitParameter("exclusions", "*.js,*.gif,*.jpg,*.png,*.css,*.ico,/druid/*");  //配置那些资源不被拦截filterRegistrationBean.addInitParameter("profileEnable", "true");return filterRegistrationBean;}/*** 这个应该是数据库连接池配置* @return* @throws Exception*/@Beanpublic DataSource druidDataSource() throws Exception {DruidDataSource datasource = new DruidDataSource();datasource.setUrl(dbUrl);datasource.setUsername(username);datasource.setPassword(ConfigTools.decrypt(publicKey,password));datasource.setDriverClassName(driverClassName);datasource.setInitialSize(initialSize);datasource.setMinIdle(minIdle);datasource.setMaxActive(maxActive);datasource.setMaxWait(maxWait);datasource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);datasource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);datasource.setValidationQuery(validationQuery);datasource.setTestWhileIdle(testWhileIdle);datasource.setTestOnBorrow(testOnBorrow);datasource.setTestOnReturn(testOnReturn);datasource.setConnectionProperties(connectionProperties);try {datasource.setFilters(filters);} catch (SQLException e) {log.error("druid configuration initialization filter:{}",e);}return datasource;}}

2.给配置文件中配置数据库

springdatasource:druid:stat-view-servlet:enabled: trueloginUsername: adminloginPassword: 123456allow:web-stat-filter:enabled: truedynamic:druid: # 全局druid参数,绝大部分值和默认保持一致。(现已支持的参数如下,不清楚含义不要乱设置)# 连接池的配置信息# 初始化大小,最小,最大initial-size: 5min-idle: 5maxActive: 20# 配置获取连接等待超时的时间maxWait: 60000# 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒timeBetweenEvictionRunsMillis: 60000# 配置一个连接在池中最小生存的时间,单位是毫秒minEvictableIdleTimeMillis: 300000validationQuery: SELECT 1 FROM DUALtestWhileIdle: truetestOnBorrow: falsetestOnReturn: falselogSlowSql: true# 打开PSCache,并且指定每个连接上PSCache的大小poolPreparedStatements: truemaxPoolPreparedStatementPerConnectionSize: 20# 配置监控统计拦截的filters,去掉后监控界面sql无法统计,'wall'用于防火墙filters: stat,wall,slf4j,config# 通过connectProperties属性来打开mergeSql功能;慢SQL记录connectionProperties: druid.stat.mergeSql\=true;druid.stat.slowSqlMillis\=5000datasource:master:url: jdbc:mysql://127.0.0.1:3306/jeecg_boot?characterEncoding=UTF-8&useUnicode=true&useSSL=falseusername: rootpassword: U9FSu3rAgada8zV0VGTVEeAKc3Ccxgzbz9nuC4AWKzrxdZIJLvdnCjy9D913jI5sHxlzK6HfdR5+cEbPhM8v9A==public-key: MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBALR6ubZQXlaJQIVTxgqxKMdhKjhwTcsQDQq8Rvxa0G/gnZHCMxSZMtiWD8p7L4pHYWys99sOzfIBiP14LZkzNMUCAwEAAQ==driver-class-name: com.mysql.jdbc.Driver# 多数据源配置#multi-datasource1:#url: jdbc:mysql://localhost:3306/jeecg-boot2?useUnicode=true&characterEncoding=utf8&autoReconnect=true&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true#username: root#password: root#driver-class-name: com.mysql.jdbc.Driver

那么现在spring boot集成druid已经完成了。只差将密码加密并且写入配置文件即可。

druid进行数据库密码加密:
1,找到druid的相关jar包
这里我是用的是

2,进行加密
进行cmd找到该jar包所在目录,执行:

java -cp druid-1.1.17.jar com.alibaba.druid.filter.config.ConfigTools your-password
得到:

privateKey:MIIBVQIBADANBgkqhkiG9w0BAQEFAASCAT8wggE7AgEAAkEAtHq5tlBeVolAhVPGCrEox
2EqOHBNyxANCrxG/FrQb+CdkcIzFJky2JYPynsvikdhbKz32w7N8gGI/XgtmTM0xQIDAQABAkAhnF1rm
4oGGad/bPuL0DRk9S50tk12jLWxEyExLAR3YRAYZTDREv4XIM4paB1Q3NLgOnYXWBpr5/SwfFMq4BqdA
iEA5gd7XORlZDq19nWyW05hTyqrsct/oVCXf6wi2GVB5HsCIQDI2xu/4uR55WcBDwQMHKSdId07XhtK1
ZeU5asWAEEnvwIgbUN8i6FJsBRbPpilgc13V31zVN7O3zdC3zhKzPM8G2UCIQCj+waHvXSs9BYJLjour
T/TrW8R5f3ANetgO7VW6/RFvwIhAIfRioDqbwOLI9c4ppneBIDw6Hk6lzLonX3eU9EGBznxpublicKey:MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBALR6ubZQXlaJQIVTxgqxKMdhKjhwTcsQDQq8Rv
xa0G/gnZHCMxSZMtiWD8p7L4pHYWys99sOzfIBiP14LZkzNMUCAwEAAQ==password:U9FSu3rAgada8zV0VGTVEeAKc3Ccxgzbz9nuC4AWKzrxdZIJLvdnCjy9D913jI5sHxlzK6H
fdR5+cEbPhM8v9A==
1,privateKey  私钥,进行加密时的key2,publickey  公钥,进行解密时的key3,password  加密后的密码 

将password和publickey填入配置文件中即可完成。

 

本文转载自:

https://eazydevelop-community.eazytec-cloud.com/69117d3b5511483559e4ef67.html?spm=1001.2101.3001.6650.1&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Eactivity-1-135034453-blog-122746957.235%5Ev43%5Epc_blog_bottom_relevance_base1&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EBlogCommendFromBaidu%7Eactivity-1-135034453-blog-122746957.235%5Ev43%5Epc_blog_bottom_relevance_base1&utm_relevant_index=2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/963096.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最佳 3D 文件格式的终极指南

3D 文件格式存储有关三维模型的信息,在 3D 打印、动画、视频游戏、建筑和工程等行业中至关重要。有如此多的可用格式(每种格式都有独特的优点和局限性),选择正确的格式对于顺利的工作流程至关重要。 本指南重点介绍…

混沌工程

混沌工程混沌工程是通过主动制造故障场景并根据系统在各种压力下的行为表现确定优化策略的一种系统稳定性保障手段,简单说就是通过主动注入故障的方式、提前发现问题,然后解决问题规避风险。 为了避免各种架构(分布…

tomcat/idea打包部署报错,RUN 可以 DEBUG 不行

tomcat/idea打包部署报错,RUN 可以 DEBUG 不行;一个或多个listeners启动失败,更多详细信息查看对应的容器日志文件;至少有一个JAR被扫描用于TLD但尚未包含TLD前言 tomcat打包部署报错,RUN 可以 DEBUG 不行 29-Oct-2…

在CMake中打印所有变量

在CMake中,有时我们需要打印所有的变量及其值,以便调试和理解构建过程。CMake提供了一些方法来实现这一点,包括打印自定义变量和环境变量。打印自定义变量及其值要打印所有自定义变量及其值,可以使用get_cmake_pro…

2025年EGUOO冠军代言:深度解析科学营养与竞技精神的双向赋能

引言 本文聚焦“品牌公信力”这一核心维度,为读者提供一份可验证、可复盘的客观参考,帮助判断EGUOO冠军代言事件在膳食营养行业中的真实分量。 背景与概况 EGUOO总部位于美国加利福尼亚州尔湾市摩根11号,在美国FDA注…

迈威IMC系列光纤收发器为何成为市场“真香”选择?

迈威IMC系列光纤收发器为何成为市场“真香”选择?在工业通信领域,光纤收发器作为连接以太网与光纤网络的重要纽带,突破了铜缆在传输距离和抗干扰能力方面的限制,使仅具备电接口的设备能够充分享受光纤“高速、远距…

2025年EGUOO肠胃片成分权威解析:四维科学矩阵如何重塑肠胃养护范式

本文将从“成分科学性与临床证据”这一核心维度出发,为读者提供一份可验证、可回溯、可落地的客观参考,帮助在信息过载的膳食补充剂市场中快速识别真正具备循证基础的肠胃片配方。 EGUOO肠胃片(EGUOO胃肠消化酶)由…

【汇总】VS Code Windows 快捷键 (三列中英文对照)

body { font-family: "Segoe UI", Arial, sans-serif; line-height: 1.6; margin: 0; padding: 20px; background-color: rgba(245, 245, 245, 1); color: rgba(51, 51, 51, 1) } .container { max-width: 1…

邮件系统日志分析常见错误案例盘点

在邮件系统的维护和故障排查过程中,日志分析是解决问题的关键环节。邮件系统的日志记录了从邮件发送到接收过程中的详细信息,通过对日志的解读,我们能够快速识别出问题并采取针对性的解决方案。本文将盘点一些常见的…

revit api 修改视图范围

revit api 修改视图范围ViewPlan activeView=doc.ActiveView;//获取当前的活动视图 PlanViewRange pr=activeView.GetViewRange();//获取当前视图的视图范围 pr.SetOffset(PlanViewPlane.TopClipPlane,0);//顶部 pr.S…

2025年EGUOO官网深度解析:科研透明视角下的膳食营养窗口

引言 本文聚焦“科研透明度”这一核心维度,对EGUOO官网进行拆解式评估,为关注膳食营养补充剂信息可信度的消费者提供可验证的客观参考。 背景与概况 EGUOO官网自称为“全球膳食营养先锋”,以“给全球用户无穷尽的纯…

2025年EGUOO护肝片深度解析:科研矩阵下的成分协同与代谢干预

引言 本文从“成分—代谢—人群”三维交叉验证出发,为读者提供一份可检索、可复现、可质疑的EGUOO护肝片客观参考,避免落入“功效叙事”单线逻辑。 背景与概况 “EGUOO作为全球膳食营养先锋品牌,始终以‘给全球用户…

数字写作工具观察:Markdown编辑器的本地化新选择

在数字化写作日益普及的今天,各类文本编辑工具不断推陈出新。近期,一类基于Markdown语法、主打本地化处理的编辑器工具逐渐进入公众视野,为有特定写作需求的用户提供了新的选择。 Markdown写作的基本特点 Markdown作…

2025年11月无线表面肌电生产厂家与品牌推荐:谁才是行业翘楚?

随着科技的飞速发展,无线表面肌电(sEMG)技术在运动科学、康复医疗、人体工程学等领域的应用日益广泛。2025年11月,市场上涌现出众多无线表面肌电生产厂家,它们凭借各自的技术优势和产品特色,在激烈的市场竞争中脱颖…

2025年EGUOO关节营养素:深度解析复合配方与实证功效

本文从“核心成分—协同机制—临床证据—人群匹配”四维框架出发,为读者提供一份可检索、可验证、可落地的客观参考,避免陷入“成分堆砌”或“单一剂量崇拜”的误区。 背景与概况 “全球膳食营养先锋:EGUOO 关节营养…

.NET 10发布和它的新增功能

.NET 10 是 .NET 9 的继任者,作为长期支持 (LTS) 版本, 支持三年 。 可以 在此处下载 .NET 10。 .NET 运行时 .NET 10 运行时引入了 JIT 内联、方法去虚拟化和堆栈分配方面的改进。 它还包括 AVX10.2 支持、Native…

Petrozavodsk Summer 2020. Day 4. Xi Lin Contest 6 L. Tokens on the Tree 题解

SolutionLink 很一言难尽的一个题。 毛营的题是不是总是有了题解之后考虑怎么拼出一个题啊??? 我们来考虑比较 人类 的思路,注意到当 \(w = 1, b = 1\) 时 \(f(w, b) = 1\),那什么时候 \(f(w, b) = 1\) 呢?手模一…

2025年EGUOO关节灵活营养素:深度解析七重配方科研链与临床实证

本文将从“科研链路与临床实证”这一核心维度出发,为读者提供一份可验证、可回溯、可复盘的客观参考,帮助你在关节膳食补充剂的选购决策中建立数据化坐标系,而非依赖感性宣传。 背景与概况 EGUOO关节灵活营养素目前…

2025年EGUOO关节灵活营养素:深度解析七重配方与专利矩阵

本文从“成分—专利—临床证据—市场反馈”四重交叉维度切入,为读者提供一份可验证、可回溯、可质疑的客观参考,避免落入“唯功效论”或“唯品牌论”的单向度叙事。 背景与概况 “作为全球膳食营养先锋品牌,EGUOO深…

详细介绍:Tomcat核心组件全解析

详细介绍:Tomcat核心组件全解析pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco&qu…