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全新亮相,开启开源新时代,内置全新数据结构...

相关推荐
步步为营DotNet1 小时前
深度解析CancellationToken:.NET中的优雅取消机制
java·前端·.net
leobertlan7 小时前
2025年终总结
前端·后端·程序员
面向Google编程8 小时前
从零学习Kafka:数据存储
后端·kafka
易安说AI9 小时前
Claude Opus 4.6 凌晨发布,我体验了一整晚,说说真实感受。
后端
易安说AI9 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
易安说AI9 小时前
用 Claude Code 远程分析生产日志,追踪 Claude Max 账户被封原因
后端
JH30739 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
颜酱10 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
Coder_Boy_10 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble11 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat