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方法进行解密

相关推荐
CV_J3 小时前
安装kibana
java·elasticsearch·spring cloud·docker·容器
码农水水5 小时前
国家电网Java面试被问:TCP的BBR拥塞控制算法原理
java·开发语言·网络·分布式·面试·wpf
浮尘笔记5 小时前
Go语言临时对象池:sync.Pool的原理与使用
开发语言·后端·golang
qq_336313935 小时前
java基础-网络编程-TCP
java·网络·tcp/ip
咕噜咕噜啦啦6 小时前
Java期末习题速通
java·开发语言
盐真卿6 小时前
python2
java·前端·javascript
梦梦代码精6 小时前
BuildingAI vs Dify vs 扣子:三大开源智能体平台架构风格对比
开发语言·前端·数据库·后端·架构·开源·推荐算法
一嘴一个橘子7 小时前
mybatis - 动态语句、批量注册mapper、分页插件
java
组合缺一7 小时前
Json Dom 怎么玩转?
java·json·dom·snack4
REDcker7 小时前
RESTful API设计规范详解
服务器·后端·接口·api·restful·博客·后端开发