姚强 2020-02-01
一.为什么要使用jasypt库?
目前springboot单体应用项目中,甚至没有使用外部配置中心的多服务的微服务架构的项目,开发/测试/生产环境中的密码往往是明文配置在yml或properties文件中,
这样就会导致密码泄露的安全隐患,被不法人员利用从而泄露公司数据信息
因此,jasypt库能通过密码加密减少明文密码泄露的风险;
二.什么是jasypt库?
参考:http://www.jasypt.org/index.html
Jasypt是一个Java库,允许开发人员以最小的努力将基本的加密功能添加到他/她的项目中,而无需对密码学的工作原理有深入的了解。
1.用于单向和双向加密的高安全性,基于标准的加密技术。加密密码,文本,数字,二进制文件...
2.与Hibernate透明集成。
3.适用于集成到基于Spring的应用程序中,还可以与Spring Security透明集成。
4.用于加密应用程序(即数据源)配置的集成功能。
5.多处理器/多核系统中高性能加密的特定功能。
6.与任何JCE提供程序一起使用的开放API。
通俗一点就是,方便开发者使用的一个密码加密库的Java库
三.怎么使用jasypt库?
以单体Springboot项目为例,Springboot版本2.1.x,Java8
1.引入jasypt库的 maven依赖
<dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</artifactId> <version>2.0.0</version> </dependency>
2.yml文件中配置jasypt 加密密码
jasypt: encryptor: password: Gabriel
3.启动类添加@EnableEncyptableProperties注解
@SpringBootApplication @MapperScan(basePackages = "com.gabriel.stage.mapper") @EnableEncryptableProperties public class StageApplication { public static void main(String[] args) { SpringApplication.run(StageApplication.class, args); } }
4.通过jar包加密数据库的明文密码
password密码 使用ENC(加密后的密码)配置