Spring Boot 配置明文密码加密,防泄漏

在Spring Boot应用中,出于安全考虑,通常不推荐在配置文件中明文存储数据库、Redis等密码。为了安全管理密码,今天给大家推荐一个安全好用实现,请往下看!!!

1,引入依赖

在pom.xml中,引入以下依赖:

xml 复制代码
<dependency>    <groupId>com.github.ulisesbocchio</groupId>    <artifactId>jasypt-spring-boot-starter</artifactId>    <version>3.0.4</version></dependency>

2,添加配置

在项目的application.yml (或 application.properties)中,添加如下配置:

perl 复制代码
jasypt:   encryptor:       password: p@ssw0rd&Hubt2ec980e$tts       algorithm: PBEWithMD5AndDES
       # 配置初始化向量生成器,解决Jasypt 3.0.3及以上版本启动报错的问题       # NoIvGenerator表示不使用向量生成器(即无向量)       iv-generator-classname: org.jasypt.iv.NoIvGenerator

3,生成密码的加密串

先写一个工具类,在工具类中生成密码的密文。

typescript 复制代码
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;
public class JasyptUtils {
    public static void main(String[] args) {
          //你的明文密码          String password = "Mysql@123";          //自定义秘钥,与配置文件中的 jasypt.encryptor.password 保持一致          String secretKey = "p@ssw0rd&Hubt2ec980e$tts";          // 算法,与配置文件中的 jasypt.encryptor.algorithm 保持一致          String algorithm = "PBEWithMD5AndDES";          // 创建加密器对象          StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();          encryptor.setPassword(secretKey);          encryptor.setAlgorithm(algorithm);                    // 执行加密操作          System.out.println("加密前:" + password);          String encryptedPassword = encryptor.encrypt(password);          System.out.println("加密后:" + encryptedPassword);        }}

4,替换明文密码

在配置文件中,用上面工具生成的加密串,替换明文密码。

配置方式:ENC(加密串)

注意:jasypt.encryptor.passwordjasypt.encryptor.algorithm 在工具类生成加密串时必须与配置文件中保持一致。

往期文章:

Java 8 到 Java 24 新特性一览

Spring AI基于DeepSeek实战,使AI开发更高效

【JAVA多线程】JDK中的各种锁,看这一篇就够了

现在的背调,都可以这么玩了?

Redis8.0全新亮相,开启开源新时代,内置全新数据结构...

相关推荐
能摆一天是一天29 分钟前
JAVA stream().flatMap()
java·windows
颜如玉1 小时前
🤲🏻🤲🏻🤲🏻临时重定向一定要能重定向🤲🏻🤲🏻🤲🏻
java·http·源码
程序员爱钓鱼2 小时前
Go语言实战案例 — 工具开发篇:实现一个图片批量压缩工具
后端·google·go
程序员的世界你不懂3 小时前
【Flask】测试平台开发,新增说明书编写和展示功能 第二十三篇
java·前端·数据库
星空寻流年3 小时前
设计模式第一章(建造者模式)
java·设计模式·建造者模式
gb42152873 小时前
java中将租户ID包装为JSQLParser的StringValue表达式对象,JSQLParser指的是?
java·开发语言·python
曾经的三心草4 小时前
Python2-工具安装使用-anaconda-jupyter-PyCharm-Matplotlib
android·java·服务器
Metaphor6924 小时前
Java 高效处理 Word 文档:查找并替换文本的全面指南
java·经验分享·word
ChinaRainbowSea4 小时前
7. LangChain4j + 记忆缓存详细说明
java·数据库·redis·后端·缓存·langchain·ai编程
舒一笑4 小时前
同步框架与底层消费机制解决方案梳理
后端·程序员