SpringBoot如何处理配置文件的密文
itomcoil 2025-09-06 02:15 4 浏览
在 Spring Boot 应用中,直接在配置文件(如 application.yml 或 application.properties)中明文存储数据库密码、API 密钥等敏感信息是严重的安全风险,尤其是在代码仓库或生产环境中。
为了提升安全性,需要对配置文件中的敏感信息进行加密处理(密文),并在应用启动时自动解密。
一、使用 Jasypt(最常用)
Jasypt 是一个流行的 Java 加解密库,与 Spring Boot 集成非常方便。
1. 添加依赖
<dependency>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-spring-boot-starter</artifactId>
<version>3.0.5</version>
</dependency>
2. 加密敏感数据(命令行工具)
# 下载 jasypt 包或使用 Maven 插件
java -cp jasypt-1.9.3.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI \
input="mysecretdbpassword" \
password=masterkey \
algorithm=PBEWithMD5AndDES
输出:
**** Encrypted with DEFAULT algorithm
ENC(v98Dv8f3p+2qQ1234567890=)
3. 在配置文件中使用密文
# application.yml
spring:
datasource:
url: jdbc:mysql://localhost:3306/mydb
username: root
password: ENC(v98Dv8f3p+2qQ1234567890=) # 使用 ENC() 包裹密文
# 配置 jasypt 解密密钥
jasypt:
encryptor:
password: masterkey # 解密主密钥(必须安全存储)
也可以通过环境变量传入主密钥:
java -jar app.jar --jasypt.encryptor.password=${DECRYPT_KEY}
4. 启动应用
Jasypt 会自动解密 ENC(...) 中的内容并注入到 Spring 容器中。
二、使用 阿里云 KMS + ACMS(云原生方案)
如果你的应用部署在阿里云,推荐使用 ACMS(应用配置管理) 或 KMS(密钥管理服务) 实现更安全的密钥管理。
特点:
- 密钥由 KMS 托管,不存储在本地。
- 配置集中管理,支持动态更新。
- 支持自动轮换密钥。
集成方式:
- 将敏感配置存储在 ACMS/Nacos 配置中心。
- 使用 KMS 对配置值进行加密。
- 应用启动时通过 SDK 从 ACMS 获取配置,并用 KMS 解密。
三、使用 HashiCorp Vault
Vault 是一个开源的 secrets 管理工具,功能强大。
集成步骤:
- 启动 Vault 服务,存储加密的数据库密码等。
- 使用 spring-cloud-starter-vault-config 依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-vault-config</artifactId>
</dependency>
配置连接 Vault:
spring:
cloud:
vault:
uri: https://vault.example.com
token: s.1234567890abcdef
kv:
enabled: true
backend: secret
profile-separator: '/'
在 Vault 中存储:
Path: secret/myapp
Data:
db-password: "encrypted-or-plain"
在代码中使用:
@Value("${db-password}")
private String dbPassword;
四、使用环境变量(简单有效)
最简单的方式是完全不在配置文件中写密码,而是通过环境变量注入。
示例:
# application.yml
spring:
datasource:
password: ${DB_PASSWORD:defaultpass} # 从环境变量读取
启动时设置:
export DB_PASSWORD=mypassword123
java -jar myapp.jar
或在 Docker 中:
ENV DB_PASSWORD=mypassword123
或 Kubernetes:
env:
- name: DB_PASSWORD
valueFrom:
secretKeyRef:
name: db-secret
key: password
推荐:环境变量 + Secret 管理(如 K8s Secrets) 是生产环境的最佳实践之一。
五、自定义加解密组件(高级)
可以实现自己的 PropertySource 或使用 EnvironmentPostProcessor 在 Spring 启动早期解密配置。
示例:
public class DecryptPropertySource extends EnumerablePropertySource<String> {
// 自定义解密逻辑
@Override
public Object getProperty(String name) {
String value = source.getProperty(name);
if (value != null && value.startsWith("ENC(")) {
return decrypt(value.substring(4, value.length() - 1));
}
return value;
}
}
然后通过 spring.factories 注册:
org.springframework.boot.env.EnvironmentPostProcessor=com.example.DecryptEnvironmentPostProcessor
六、最佳实践总结
方案 | 适用场景 | 安全性 | 复杂度 |
Jasypt | 单体应用、快速集成 | ||
环境变量 + Secret | Docker/K8s/云环境 | ||
Vault | 微服务、多环境、高安全要求 | ||
阿里云 ACMS/KMS | 阿里云生态 | ||
自定义解密 | 特殊需求 |
推荐策略:
- 开发环境:使用 Jasypt 或明文(仅限本地)。
- 测试/预发环境:使用环境变量或配置中心。
- 生产环境:
- 优先使用 K8s Secrets + 环境变量
- 或 Vault / ACMS + KMS
- 避免将主密钥(master password)硬编码在代码或配置中。
七、注意
- 主密钥安全:无论使用哪种方案,主密钥(Master Key)必须安全存储,推荐使用环境变量或云厂商的密钥管理服务。
- 不要提交密钥到 Git:.gitignore 排除包含密钥的文件。
- 定期轮换密钥:尤其是数据库密码、API Key。
- 日志脱敏:确保日志中不会打印解密后的敏感信息。
相关推荐
- Filter函数在WPS里的正确用法,官方教程里都没有说......
-
Filter函数是office365新增的筛选函数,WPS也紧跟添加了它。但在二个软件中的使用方法却完全不同。office365有单元格溢出功能,只需要输入一个Filter公式即可完成数据筛选。但在W...
- 跳过VLOOKUP天坑!FILTER函数10个招式让同事以为你开了外挂?
-
还在为VLOOKUP的"一对多"限制头疼?是否还在为INDEX+MATCH的嵌套抓狂?今天教你用Excel新晋顶流——FILTER函数,10个高能用法让你秒变数据操控大师!用法1:精准...
- Filter函数的三种用法,比用VLOOKUP一对多查询,更加灵活方便
-
文章最后有彩蛋!好礼相送!Excel秘籍大全,正文开始FILTER函数可以基于定义的条件筛选一系列数据。在没有filter函数之前,如果实现一对多查询,常见的是构建辅助列,然后使用VLOOKUP+R...
- Filter函数公式,快速实现订单核对,1分钟学会
-
举个例子,我们有一份公司所有的订单源数据表格,这里我们只用两列信息来模拟,实际可能有很多列数据,几百行数据然后我们有另外一个表,里面有部分已经处理过的订单数据,如下所示,这里举例是4个,实际可能有上百...
- FILTER函数结合及经典用法2:一对多筛选
-
FILTER经典用法2:一对多筛选。FILTER函数的经典用法2:一对多的筛选。比如左边这个表格,需要根据部门筛选出每个部门的人员,应该怎样做?·把鼠标放在单元格内,在编辑栏输入等于FILTER。·第...
- 干掉VLOOKUP,FILTER函数9大用法全解析!
-
1.单条件基础筛选场景:筛选销量>5000的记录公式:=VSTACK(A1:D1,FILTER(A2:D9,D2:D9>5500))解析:A2:D9为需要筛选的数据区域,D2:D9&...
- Excel新函数公式Filter,秒杀VLOOKUP,人人必学
-
以前VLOOKUP公式是必学的公式,自从新版本更新之后,VLOOKUP已经变得可有可无了,但是新出来的Filter函数公式,你必须学会,它非常的强大,工作中用到非常频繁1、Filter公式背景在学会这...
- 第一讲:filter的基本用法及拓展_filter详解
-
全能查找函数filter的基本用法及拓展初学者,务必观看。进阶者,可互相学习,欢迎在回复中补充新用法。首次撰写此函数相关内容,若有不足之处,请予以指教,请勿诋毁,多谢。提示:以下内容以WPS最新版本为...
- 测一测你是什么粒子?_测测你是什么质
-
大亚湾实验。|图片来源:RoyKaltschmidt,LawrenceBerkeleyNationalLaboratory/WikimediaCommons2020年12月12日,大亚湾...
- SpringBoot如何处理配置文件的密文
-
在SpringBoot应用中,直接在配置文件(如application.yml或application.properties)中明文存储数据库密码、API密钥等敏感信息是严重的安全风险,...
- 大语言模型解释Python的 类装饰器
-
一、什么是类装饰器?在Python中,装饰器(Decorator)是一种高阶函数,它接受另一个对象(通常是函数或类),并返回一个经“增强”处理后的新对象。我们常见的是对函数进行装饰:@my_dec...
- Thymeleaf_thymeleaf属于前端吗
-
一、Thymeleaf简介Thymeleaf是用来开发Web和独立环境项目的服务器端的Java模版引擎Spring官方支持的服务的渲染模板中,并不包含jsp。而是Thymeleaf和Freemarke...
- Win9去哪了?Win10避讳Windows95、98
-
10月1日,微软在旧金山发布了新一代操作系统预览版。但不是名为Windows9,而是win10,有业内人士猜测,跳过9而取10为命名是为了预示十全十美。可是小编还觉得9还代表长长久久呢!恐怕这里又说...
- 仓颉编程练习-字符串操作_仓颉编译器
-
main.cj:importstd.convert.Parsablemain():Int64{//字符串比较lets1:String="abc"...
- 一课译词:断断续续_一课译词:断断续续的意思
-
PhotobyMikefromPexels“断断续续”,或“时断时续”,意思是时而中断,时而继续地接连下去(continuefromtimetotime)。与英文惯用语“fitsan...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)