SpringBoot集成配置文件加解密

前言

在SpringBoot的配置文件中,有些配置是比较敏感的,例如密码等信息,因此,对这些配置文件加密是很有必要的,下面介绍一种配置加解密的集成方式。

详细操作

Jasypt是SpringBoot项目中常用的配置加解密工具,我们引入asypt-spring-boot-starter依赖

yaml 复制代码
<!--配置文件加密值自动解密-->
        <dependency>
            <groupId>com.github.ulisesbocchio</groupId>
            <artifactId>jasypt-spring-boot-starter</artifactId>
            <version>3.0.4</version>
        </dependency>
        <dependency>
            <groupId>org.gm</groupId>
            <artifactId>crypto</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

然后定义一个名为jasyptStringEncryptor的bean即可

yaml 复制代码
package com.example.rocketmq.rocketmq.config;

import com.crypto.sm.SMHelper;
import org.jasypt.encryption.StringEncryptor;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.stereotype.Component;

/**
 * 配置解密
 */
@Component("jasyptStringEncryptor")
@ConditionalOnProperty(prefix = "property.encry.enable",name = "enable",havingValue = "true", matchIfMissing = true)
public class PropertyEncryptor implements StringEncryptor {
    private final String KEY = "xxxxxxxxx";
    @Override
    public String encrypt(String s) {
        if(s != null) {
            return SMHelper.sm4Encrypt(KEY, s);
        }
        return s;
    }

    @Override
    public String decrypt(String s) {
        if(s != null) {
            return SMHelper.sm4Decrypt(KEY, s);
        }
        return s;
    }

    public static void main(String[] args) {
        System.out.println(SMHelper.sm4Encrypt("mHApUC5BL6AEzAr3", "root123"));
    }
}

这样,我们使用sm4加密密钥对配置值加密,得到加密串,在配置文件配置xxx=ENC(加密值)即可

工作原理

在Spring Boot启动时,会加载各种PropertySource(包括application.yml、Nacos配置等)。Jasypt会通过一个Bean后置处理器(BeanFactoryPostProcessor)来拦截PropertySource的加载,并将其包装成可解密的PropertySource。当Spring从Environment中获取属性时,如果遇到以ENC(开头和)结尾的属性值,就会调用配置的StringEncryptor的decrypt方法进行解密

相关推荐
一直都在5721 小时前
Java死锁
java·开发语言
IT_陈寒1 小时前
深入理解JavaScript:核心原理与最佳实践
前端·人工智能·后端
树獭叔叔1 小时前
GRPO:比PPO更简单的RLHF算法
后端·aigc·openai
shelter1 小时前
并发操作session对象导致登录闪退问题
后端
兆子龙2 小时前
TypeScript高级类型编程:从入门到精通
前端·后端
IT_陈寒2 小时前
Python开发者的效率革命:这5个技巧让你的代码提速50%!
前端·人工智能·后端
MekoLi292 小时前
Spring AI 与 LangChain4j 从入门到精通:Java 后端开发者的 AI 实战手册
后端·面试
我真会写代码2 小时前
深度解析并发编程锁升级:从偏向锁到重量级锁,底层原理+面试考点全拆解
java·并发编程·
树獭叔叔2 小时前
从RLHF到PPO:让AI学会说人话
后端·aigc·openai
Meepo_haha2 小时前
创建Spring Initializr项目
java·后端·spring