• 一个依赖搞定Spring Boot 配置文件脱敏


    经常会遇到这样一种情况:项目的配置文件中总有一些敏感信息,比如数据源的url、用户名、密码....这些信息一旦被暴露那么整个数据库都将会被泄漏,那么如何将这些配置隐藏呢?

    今天介绍一种方案,让你在无感知的情况下实现配置文件的加密、解密。利用一款开源插件:jasypt-spring-boot。项目地址如下:

    https://github.com/ulisesbocchio/jasypt-spring-boot
    

    使用方法很简单,整合Spring Boot 只需要添加一个starter

    1. 添加依赖

    1. <dependency>
    2.         <groupId>com.github.ulisesbocchio</groupId>
    3.         <artifactId>jasypt-spring-boot-starter</artifactId>
    4.         <version>3.0.3</version>
    5. </dependency>  

    2. 配置秘钥

    在配置文件中添加一个加密的秘钥(任意),如下:

    1. jasypt:
    2.   encryptor:
    3.     password: Y6M9fAJQdU7jNp5MW

    当然将秘钥直接放在配置文件中也是不安全的,我们可以在项目启动的时候配置秘钥,命令如下:

    java -jar xxx.jar  -Djasypt.encryptor.password=Y6M9fAJQdU7jNp5MW
    

    3. 生成加密后的数据

    这一步骤是将配置明文进行加密,代码如下:

    1. @SpringBootTest
    2. @RunWith(SpringRunner.class)
    3. public class SpringbootJasyptApplicationTests {
    4.     /**
    5.      * 注入加密方法
    6.      */
    7.     @Autowired
    8.     private StringEncryptor encryptor;
    9.     /**
    10.      * 手动生成密文,此处演示了url,user,password
    11.      */
    12.     @Test
    13.     public void encrypt() {
    14.         String url = encryptor.encrypt("jdbc\\:mysql\\://127.0.0.1\\:3306/test?useUnicode\\=true&characterEncoding\\=UTF-8&zeroDateTimeBehavior\\=convertToNull&useSSL\\=false&allowMultiQueries\\=true&serverTimezone=Asia/Shanghai");
    15.         String name = encryptor.encrypt("root");
    16.         String password = encryptor.encrypt("123456");
    17.         System.out.println("database url: " + url);
    18.         System.out.println("database name: " + name);
    19.         System.out.println("database password: " + password);
    20.         Assert.assertTrue(url.length() > 0);
    21.         Assert.assertTrue(name.length() > 0);
    22.         Assert.assertTrue(password.length() > 0);
    23.     }
    24. }

    上述代码对数据源的url、user、password进行了明文加密,输出的结果如下:

    1. database url: szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=
    2. database name: L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm
    3. database password: EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ

    4. 将加密后的密文写入配置

    jasypt默认使用ENC()包裹,此时的数据源配置如下:

    1. spring:
    2.   datasource:
    3.     #   数据源基本配置
    4.     username: ENC(L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm)
    5.     password: ENC(EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ)
    6.     driver-class-name: com.mysql.jdbc.Driver
    7.     url: ENC(szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=)
    8.     type: com.alibaba.druid.pool.DruidDataSource

    上述配置是使用默认的prefix=ENC(suffix=),当然我们可以根据自己的要求更改,只需要在配置文件中更改即可,如下:

    1. jasypt:
    2.   encryptor:
    3.     ## 指定前缀、后缀
    4.     property:
    5.       prefix: 'PASS('
    6.       suffix: ')'

    那么此时的配置就必须使用PASS()包裹才会被解密,如下:

    1. spring:
    2.   datasource:
    3.     #   数据源基本配置
    4.     username: PASS(L8I2RqYPptEtQNL4x8VhRVakSUdlsTGzEND/3TOnVTYPWe0ZnWsW0/5JdUsw9ulm)
    5.     password: PASS(EJYCSbBL8Pmf2HubIH7dHhpfDZcLyJCEGMR9jAV3apJtvFtx9TVdhUPsAxjQ2pnJ)
    6.     driver-class-name: com.mysql.jdbc.Driver
    7.     url: PASS(szkFDG56WcAOzG2utv0m2aoAvNFH5g3DXz0o6joZjT26Y5WNA+1Z+pQFpyhFBokqOp2jsFtB+P9b3gB601rfas3dSfvS8Bgo3MyP1nojJgVp6gCVi+B/XUs0keXPn+pbX/19HrlUN1LeEweHS/LCRZslhWJCsIXTwZo1PlpXRv3Vyhf2OEzzKLm3mIAYj51CrEaN3w5cMiCESlwvKUhpAJVz/uXQJ1spLUAMuXCKKrXM/6dSRnWyTtdFRost5cChEU9uRjw5M+8HU3BLemtcK0vM8iYDjEi5zDbZtwxD3hA=)
    8.     type: com.alibaba.druid.pool.DruidDataSource

    5. 总结

    jasypt还有许多高级用法,比如可以自己配置加密算法,具体的操作可以参考Github上的文档。

  • 相关阅读:
    剖析虚幻渲染体系(14)- 延展篇:现代渲染引擎演变史Part 2(成长期)
    压缩文件7-Zip与WinRAR个人免费版在不同压缩等级下的对比
    ADAU1860调试心得(5)ADC-DAC直通程序
    WEB安全问题
    金仓数据库KingbaseES客户端编程开发框架-SQLAlchemy(4. 程序示例)
    RPA+AI提效降本背后的故事,来也科技这样用CRM
    Solon2 常用注解之 @ProxyComponent 用法说明
    TCP 通信并发服务器详解(附有案例代码)
    KNN 和 SVM 图片分类 任务 代码及细节分享
    淘宝API接入说明(商品详情数据示例)
  • 原文地址:https://blog.csdn.net/java_beautiful/article/details/125444876