SpringBoot配置文件加密

1 场景

SpringBoot的项目发布时,线上配置文件通常会采用spring.profiles.active参数的形式指定。

这种方式,线上配置文件,需要配置到源码中,密码等敏感信息会暴出来。

虽然数据库可以限制访问的IP来杜绝密码泄露出去后代码的非法访问问题。但是有些外部邮箱密码第三方访问接口密钥等不可控的外部接口,无法限制访问者的IP,仍然有安全问题。

2 加密方式

这里采用jasypt对SpringBoot中的配置文件信息进行加密。

配置文件中的密码信息为加密后的字符串,通过在启动时指定jasypt私钥,来进行自动解密运维人员保管维护解密的私钥

加密步骤:

(1)配置jasypt密钥,对密码进行加密

(2)将加密后的字符串以ENC(xxxx)的格式配置在配置文件中

(3)启动jar后,在参数中加上--jasypt.encryptor.password指定jasypt密钥

3 加密过程

3.1 maven依赖
<dependency>
	<groupId>com.github.ulisesbocchio</groupId>
	<artifactId>jasypt-spring-boot-starter</artifactId>
	<version>2.1.2</version>
</dependency>
3.2 配置加密密钥

这里设置加密密钥为:abcd_123

3.2.1 开发环境

开发环境可在配置文件yml中配置

jasypt:
  encryptor:
    password: abcd_123
3.2.2 生产环境

生产环境采用启动参数的形式传入:--jasypt.encryptor.password=abcd_123

如:

java -jar xxx.jar --jasypt.encryptor.password=abcd_123
3.3 加密

对字符串rootPwd进行加密:

@Autowired
private StringEncryptor encryptor;

@Test
public void encrypt(){
	System.out.println(encryptor.encrypt("rootPwd"));
}

rootPwd加密后的内容如下:

yCu0xHHOTfl8evdE0bR1Fg==
3.4 配置密文

将密码加密后生成的密文,以ENC(xxxx)的形式配置在配置文件中。

如下:

spring:
    datasource:
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://xxx.xxx.xxx.xxx:xxx/xxx
        username: root
        password: ENC(yCu0xHHOTfl8evdE0bR1Fg==)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值