SpringBoot使用jasypt加解密密码

在咱们的服务中不可避免的须要使用到一些秘钥(数据库、redis等)git

开发和测试环境还好,但生产若是采用明文配置讲会有安全问题,jasypt是一个通用的加解密库,咱们可使用它。github

<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>2.1.1</version>
</dependency>

配置文件:redis

# 加密的密钥
# 测试环境能够采用在配置文件中配置
# 生产环境建议采用启动参数的形式传入
# 其余配置参数参考:com.ulisesbocchio.jasyptspringboot.properties.JasyptEncryptorConfigurationProperties
jasypt.encryptor.password=you salt

# 解密获得原始密码
spring.datasource.password= ENC(密文)

那密文怎么来的呢?spring

@Autowired
StringEncryptor stringEncryptor;

@Test
public void encrypt() {
    System.out.println("PWD: " + stringEncryptor.encrypt("yourpassword"));
}

jasypt默认使用StringEncryptor来进行加解密,咱们也能够自定义本身的加解密类来替换它,具体用户用时请百度/google。数据库

相关文章
相关标签/搜索