工程中的配置文件如果把数据库的用户名密码写成明文的话是一件很危险的事情,之前也看见网上说可以对密码进行加密,用的时候再解密,因此今天我就尝试如何在spring boot 中的项目中实现关键信息的加密解密,并记录下来。

jasypt

  Jasypt is a java library which allows the developer to add basic encryption capabilities to his/her projects with minimum effort, and without the need of having deep knowledge on how cryptography works.

  这是摘抄自Jasypt官网的一句描述,重点就是简单方便,同时和spring能够很好的集成,尤其是还提供了对spring boot的支持,可以参考starter的实现:https://github.com/ulisesbocchio/jasypt-spring-boot

  1. Maven依赖

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

    http://central.maven.org/maven2/org/jasypt/jasypt/1.9.2/jasypt-1.9.2.jar

  1. 加密密码

    加密命令如下(红色部分代表需要加密的密码):

    java -cp F://.m2/repository/org/jasypt/jasypt/1.9.2/jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI input="test123" password=e9fbdb2d3b21 algorithm=PBEWithMD5AndDES

    命令回显如下(红色部分是加密后的密文):

    ----ENVIRONMENT-----------------
    Runtime: Oracle Corporation Java HotSpot(TM) 64-Bit Server VM 25.121-b13
    ----ARGUMENTS-------------------
    algorithm: PBEWithMD5AndDES
    input: test123
    password: e9fbdb2d3b21
    ----OUTPUT----------------------
    ArGx5ir2xs+CmXRhMnThpQ==
  2. 在程序中设置密文

    在程序中设置密文需要使用如下格式:

    ENC(密文)
    如:
    spring.datasource.password=ENC(ArGx5ir2xs+CmXRhMnThpQ==)

    在程序中获取到的spring.datasource.password会自动转换成明文内容(test123)。

  3. 配置密文密码

    在启动命令中配置JVM参数(jasypt.encryptor.password),注入加密密文的密码。
    如:

    java -Dfile.encoding=UTF8 -Djasypt.encryptor.password=e9fbdb2d3b21 -jar -Xmx512m settlement.jar

    注:在docker容器中密文的密码可以设置成环境变量(如:JASYPT_PASSWORD ),上述命令可以修改为:

    java -Dfile.encoding=UTF8 -Djasypt.encryptor.password=${JASYPT_PASSWORD} -jar -Xmx512m settlement.jar
  4. 参考文档
    https://www.ricston.com/blog/encrypting-properties-in-spring-boot-with-jasypt-spring-boot/
    https://github.com/ulisesbocchio/jasypt-spring-boot
好记性不如烂笔头!

最新文章

  1. ecshop调用后台指定广告位下所有广告循环
  2. MapReduce类型与格式(输入与输出)
  3. WEB框架介绍
  4. [.net 面向对象程序设计进阶] (5) Lamda表达式(一) 创建委托
  5. Joomla 3.2.0 - 3.4.4 无限制SQL注入漏洞
  6. 为网页设计师准备的30个使用的HTML5框架
  7. ganglia监控hadoop2.0配置方法
  8. OC中文件的操作
  9. Recover the String
  10. lucene 简单搜索步骤
  11. iOS 之 Strong与Weak,_unsafe _unretained与weak区别
  12. Celery(三)实例Application
  13. Windows PE入门基础知识:Windows PE的作用、命名规则、启动方式、启动原理
  14. LeetCode 20. Valid Parentheses(c++)
  15. 缓存之Memcache
  16. [福大软工] Z班 团队作业——随堂小测(同学录) 作业成绩
  17. 第一章 Android系统的编译和移植实例
  18. C与指针练习题4.14.1
  19. oracle 数据库备份、还原、和使用心得(表丢失、视图丢失的解决办法)
  20. 过河卒(NOIP2002)

热门文章

  1. MyEclipse创建maven项目时报: org.apache.maven.archiver.MavenArchiver.getManifest 错误
  2. css day2
  3. 工作中常用的linux命令大全
  4. bzoj1004 [HNOI2008]Cards Burnside 引理+背包
  5. java知识链接
  6. logback为单独的包或者类配置输出文件
  7. webpack 图片文件处理loader
  8. Oracle 包的学习
  9. Oracle序列重置
  10. Python基础教程(014)--缩进错误