SpringBoot系列---【使用jasypt把配置文件密码加密】

使用jasypt把配置文件密码加密

1.引入pom坐标

xml 复制代码
<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>3.0.5</version>
</dependency>

2.新增jasypt配置

2.1使用yml配置文件进行配置

yml 复制代码
jasypt:
  encryptor:
    password: fast_boot_security

2.2使用System进行配置(适用于代码扫描比较严格的场景,把jasypt的密码放入jvm启动参数)

java 复制代码
#在启动类中添加配置
public static void main(String[] args) {
    System.setProperty("jasypt.encryptor.password",System.getProperty("jasypt.publicKey"));
    ConfigurableApplicationContext run = SpringApplication.run(FastBootApplication.class, args);
    System.out.println("run = " + run);
}

在jvm启动参数中添加-D参数:"-Djasypt.publicKey=fast_boot_security"。

3.新增加解密测试类

java 复制代码
@RestController
@Api(tags = "ypt测试工具类")
@RequestMapping("ypt")
public class YptTestController extends BaseController {

    @Resource
    private StringEncryptor stringEncryptor;

    @ApiOperation(value = "加密")
    @PostMapping("/encrypt")
    public R<String> encrypt(String encryptStr) {
        return select(this.stringEncryptor.encrypt(encryptStr));
    }

    @ApiOperation(value = "解密")
    @GetMapping("decrypt")
    public R<String> decrypt(String decryptStr) {
        return select(this.stringEncryptor.decrypt(decryptStr));
    }
}

4.替换配置文件中的明文密码

yml 复制代码
spring:
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3307/home-finance?useSSL=false&serverTimezone=UTC&characterEncoding=utf-8
    username: root
    password: ENC(iKcnV0M2Ro4gEGmegC62bO2vb7y4wo955bpkFmn9mEKQSU63P1UtwvQKN+7MhJmywkrEauRDOAmc5ZKEZy+cg==)
相关推荐
李宥小哥6 小时前
C#基础11-常用类
android·java·c#
小许学java7 小时前
数据结构-ArrayList与顺序表
java·数据结构·顺序表·arraylist·线性表
Java 码农9 小时前
Centos7 maven 安装
java·python·centos·maven
涵涵(互关)9 小时前
Maven多模块项目MyMetaObjectHandler自动填充日期未生效
spring·maven·mybatis
harmful_sheep9 小时前
maven mvn 安装自定义 jar 包
java·maven·jar
007php0079 小时前
某大厂跳动面试:计算机网络相关问题解析与总结
java·开发语言·学习·计算机网络·mysql·面试·职场和发展
你的人类朋友9 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端
JH30739 小时前
第七篇:Buffer Pool 与 InnoDB 其他组件的协作
java·数据库·mysql·oracle
码事漫谈10 小时前
医疗设备控制系统中同步与异步通信的架构设计
后端
码事漫谈10 小时前
C++ 中 rfind 方法详解
后端