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==)
相关推荐
铁皮饭盒35 分钟前
Bun执行python代码
前端·javascript·后端
菜鸟谢1 小时前
Rust 枚举 (enum) 完整核心知识点
后端
晓杰在写后端1 小时前
从0到1实现Balatro游戏后端(9):Blind奖励结算与金币系统实现
后端·游戏开发
Patrick_Wilson1 小时前
幂等到底是什么?从前端视角讲透 SQL、HTTP 与 POST 接口的幂等设计
前端·后端·架构
凌览1 小时前
一人公司别再上 Jenkins,真不值
前端·后端
菜鸟谢2 小时前
Rust 元组与数组内存管理笔记
后端
oil欧哟2 小时前
Codex 最佳实践(超级长文):先搞懂 AI,再用好 AI
前端·人工智能·后端
AskHarries2 小时前
把一个外部系统接成 MCP 工具
后端·程序员
释然小师弟2 小时前
Android开发十年:反思与回顾
android·后端·嵌入式
用户3169353811832 小时前
如何从零编写一个 Spring Boot Starter
spring boot