springboot对数据库密码加密的实现
我是黑帽子K,话不多说直接上加密。如有不对,欢迎指正。
开发的同学们都知道,例如项目依赖的信息,数据库信息一般是保存在配置文件中,而且都是明文,因此需要进行加密处理,今天在这里介绍下jasypt集成springboot加密的配置。
首先,这些都是建立在你的springboot项目是能正常运行的前提下。
第一步:pom文件加入依赖,如图:

这里提供一个版本,
<dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</artifactId> <version>2.1.0</version></dependency>
第二步:生成密钥
找到你本地maven仓库的jasypt的jar包,在该目录下打开cmd命令窗口,如图:

执行
java -cp jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI input='test' password=test algorithm=PBEWithMD5AndDES
其中input为你的明文密码,这里我演示的是test,password为你的私钥,algorithm这个是一个规则,切勿更改!!!。执行后如图:

简单解释一下,这里的OUTPUT就是加密之后的密文(密码)。这里提供一下cmd复制文本的办法(因为我一开始也不会cmd复制):鼠标右键标记然后选中你要复制的内容,就可以复制啦。
第三步:springboot配置文件中添加配置,如图:

这里我用的是application.yml文件,application.properties文件写成这样:jasypt.encryptor.password=test。
说明:上图第一个password对应第二步中ARGUEMENTS中的password,第二个password对应第二步中OUTPUT中的结果,形式一定要加上ENC(you password),如图所示。
第四步:通过命令解密密码
执行命令
java -cp jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringDecryptionCLI input='nhyL4CzSQv/aPxoe7TzpOQ==' password=test algorithm=PBEWithMD5AndDES
结果如下图:


这里到最后就完成了springboot和jasypt的集成啦,是不是非常简单,哈哈。不过有一点要注意哦,千万不要泄露你的配置文件哦(特别是ARGUMENTS里面的password,这个相当于私钥),不然别人可以通过第四步解密你的密码,建议还是把配置文件放在配置中心,类似的有携程的阿波罗https://github.com/ctripcorp/apollo/wiki/Quick-Start,百度的disconf https://github.com/knightliao/disconf 有兴趣的同学可以去研究一下。
最后,配置过程有啥问题可以给我留言,谢谢支持。
到此这篇关于springboot对数据库密码加密的实现的文章就介绍到这了,更多相关springboot 数据库密码加密内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章:
1. Spring Framework 1.2.8发布2. HTML5视频播放标签video和音频播放标签audio标签的正确用法3. ASP基础知识Command对象讲解4. ASP.NET Core 7 Razor Pages项目发布到IIS的详细过程5. Jsp中request的3个基础实践6. 详解如何实现phpoffice的excel导入功能解耦7. vue-element-admin中node-sass换成dart-sass,安装依赖报code 128多种问题的解决方法8. Python实现自动化刷抖音的实例9. 详解CSS故障艺术10. Ajax 请求队列解决方案并结合elementUi做全局加载状态

网公网安备