Spring boot敏感参数加密配置

一,背景

在项目中很多参数会被配置到配置文件中,比如说密钥,用户名,数据库连接,账号密码之类的,如果用明文配置,会有一定的安全风险。为了减小风险,增加对敏感配置数据的加密配置。

二,实现步骤

1. 引入maven依赖

复制代码
<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>3.0.5</version>
</dependency>
<dependency>
  <groupId>org.bouncycastle</groupId>
  <artifactId>bcprov-jdk18on</artifactId>
  <version>1.78.1</version>
</dependency>

2. Application启动类配置

@EnableEncryptableProperties

3. bootstrap.yml配置

配置文件加解密配置

jasypt:

encryptor:

加解密算法

algorithm: PBEWithMD5AndDES

iv-generator-classname: org.jasypt.iv.NoIvGenerator

property:

算法识别前缀(当算法发现配置文件中的值以这前缀开始,后缀结尾时,会使用指定算法解密)

prefix: ENC(

算法识别后缀

suffix: )

4. 加解密工具类

package com.xxx.xxx;

import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;

import org.jasypt.encryption.pbe.config.EnvironmentStringPBEConfig;

public class JasyptUtils {

public static final String PASSWORD = "abc";

public static final String ALGORITHM = "PBEWithMD5AndDES";

public static void main(String[] args) {

process("root");

process("123456");

}

/**

* 加密

*

* @param plaintext 明文

* @return

*/

public static String encrypt(String plaintext) {

StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();

EnvironmentStringPBEConfig config = new EnvironmentStringPBEConfig();

// 指定算法

config.setAlgorithm(ALGORITHM);

// 指定秘钥,和yml配置文件中保持一致

config.setPassword(PASSWORD);

encryptor.setConfig(config);

// 生成加密数据

return encryptor.encrypt(plaintext);

}

/**

* 解密

*

* @param data 加密后数据

* @return

*/

public static String decrypt(String data) {

StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();

EnvironmentStringPBEConfig config = new EnvironmentStringPBEConfig();

// 指定算法

config.setAlgorithm(ALGORITHM);

// 指定秘钥,和yml配置文件中保持一致

config.setPassword(PASSWORD);

encryptor.setConfig(config);

// 解密数据

return encryptor.decrypt(data);

}

private static void process(String text) {

String ciphertext = encrypt(text);

System.out.println("ciphertext: " + ciphertext);

System.out.println("plaintext: " + decrypt(ciphertext));

System.out.println("--------------------------");

}

}

5. 将上一步得到加密后的文本写入bootstrap.yml

密文用指定的前后缀包围: ENC(xxx)

spring:

数据源

datasource:

url: ENC(Pd+8gi8reZ8qAWQmlyqeSGUfbE9McRBBADMLHOPefTQZUKGUGqmyEK8Zfk/McQZuBkku1/ukvFpoimbZ23GmBwGx3P2/LxYHUMObbBN1qj5wFlVAENDB50Or43R9oKjgbfeGgZ+v5hFP3EsUzJoBW/fVt9Wv0QLKRZ3FgZl+/1ibqdI4HON7T1cV7xtOQrcY7yKxZfozalY0jN7paaUznx6pidmjE1zLAOpfzigzxlIhcBiQeKqKfQzZLk2LSODG)

username: ENC(qFu6FeDJrXw3FV0Aqty2aw==)

password: ENC(mimO0LHX+2DzbXLZKeoXPVXVw9uzGehK)

6. 在启动命令增加秘钥环境变量

密钥: abc

java -Djasypt.encryptor.password=abc -jar xxx.jar
注意: 秘钥不可配置在bootstrap.yml, 可以放在服务器的指定位置,或者嵌入到K8s的secrect config里面。

相关推荐
invicinble3 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
小码哥_常3 小时前
MyBatis-Plus:让数据库操作飞起来的神器
后端
wbs_scy3 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
ss2734 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
2301_811274314 小时前
基于SpringBoot的智能家居管理系统
spring boot·后端·智能家居
毕设源码_古学姐4 小时前
计算机毕业设计springboot智能家居项目管理系统 基于SpringBoot的智能家居项目管理平台设计与实现 SpringBoot技术驱动的智能家居项目管理系统开发
spring boot·智能家居·课程设计
毕设源码-张学姐4 小时前
计算机毕业设计springboot智能家居设备信息管理系统 基于SpringBoot的智能家居设备全生命周期管理平台 面向智慧家庭的SpringBoot设备资产与场景运营系统
spring boot·智能家居·课程设计
AI人工智能+电脑小能手4 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
舒一笑4 小时前
我把设备指纹生成逻辑拆开了:它到底凭什么区分不同设备?
后端·程序员·掘金技术征文
try2find4 小时前
打印ascii码报错问题
java·linux·前端