当前位置: 首页 > news >正文

【SpringBoot】 jasypt配置文件密码加解密

目前我们对yml配置文件中的密码都是明文显示,显然这不安全,有的程序员离职了以后可能会做一些非法骚操作,所以我们最好要做一个加密,只能让领导架构师或者技术经理知道这个密码。所以这节课就需要来实现一下。

我们可以使用jasypt来实现密码加密的机制

common工程添加依赖:

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

创建一个test类

@SpringBootTest
public class JasyptTest {@Testpublic void testPwdEncrypt() {// 实例化加密器StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();// 配置加密算法和秘钥EnvironmentPBEConfig config = new EnvironmentPBEConfig();config.setAlgorithm("PBEWithMD5AndDES");    // 设置加密算法,默认的config.setPassword("fengjianyingyue");      // 用于加密的秘钥(盐),可以是随机字符串,一定要记住并且存储好encryptor.setConfig(config);// 对自己的密码进行加密String myPwd = "imooc";String encryptedPwd = encryptor.encrypt(myPwd);System.out.println("++++++++++++++++++++++++++++++");System.out.println("+ 原密码为:" + myPwd);System.out.println("+ 加密后的密码为:" + encryptedPwd);System.out.println("++++++++++++++++++++++++++++++");// 备注:此方式也可以用于账号密码登录的加盐操作}//    bg4mklHlRGmEUrhSr2hoCA==
//    EkSpYxuOam5DntjuV/0K3w==
//    PGUSPogsj7txKyfrjwr8lA==@Testpublic void testPwdDecrypt() {// 实例化加密器StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();// 配置加密算法和秘钥EnvironmentPBEConfig config = new EnvironmentPBEConfig();config.setAlgorithm("PBEWithMD5AndDES");    // 设置加密算法,默认的config.setPassword("fengjianyingyue");      // 用于加密的秘钥(盐),可以是随机字符串,一定要记住并且存储好encryptor.setConfig(config);String pendingPwd = "EkSpYxuOam5DntjuV/0K3w==";String myPwd = encryptor.decrypt(pendingPwd);System.out.println("++++++++++++++++++++++++++++++");System.out.println("+ 解密后的密码为:" + myPwd);System.out.println("++++++++++++++++++++++++++++++");}
}

运行结果可以看到,每次运行获得的加密密码都是不一样的。但是没关系,解密的话都是可以的。只要有秘钥,就能解密。

yml配置:

运行测试结果消息队列能否消费。

加上ENC()作为jasypt唯一识别

作业

  1. 把jasypt作为加盐的第二种方式,提供给MD5Utils作为第二种加密方式
  2. 使用nacos配置jasypt秘钥
http://www.lryc.cn/news/405246.html

相关文章:

  • 复杂网络的任意子节点的网络最短距离
  • (Qt) 文件读写基础
  • 全产业布局对穿戴甲品牌连锁店的意义
  • git的一些使用技巧(git fetch 和 git pull的区别,git merge 和 git rebase的区别)
  • 展厅中控系统有哪些优势呢
  • FPGA开发在verilog中关于阻塞和非阻塞赋值的区别
  • 动态特征转换的艺术:在Mojo模型中实现自定义变换的策略
  • 如何让Python爬虫在遇到异常时继续运行
  • 手把手带你搭建Snort入侵检测系统
  • 小程序内嵌uniapp页面跳转回小程序指定页面方式
  • 基于 Three.js 的 3D 模型加载优化
  • Jlink下载与适配keil ccs theia教程 用jlink代替ti自己的下载仿真器
  • C# 进制之间的转换(二进制,八进制,十进制,十六进制)
  • Linux 基础开发工具 : Vim编辑器
  • Delphi 11.2 配置Android SDK 环境
  • Spring Boot 学习(10)——固基(Idea 配置 git 访问 gitee)
  • 11 个接口性能优化技巧(上)【送源码】
  • AIoTedge 智能边缘物联网平台
  • 深入理解CSS基础【代码审计实战指南】
  • html改写vue日志
  • Transformer-Bert---散装知识点---mlm,nsp
  • 基于术语词典干预的机器翻译挑战赛笔记 Task3 #Datawhale AI 夏令营
  • 定制QCustomPlot 带有ListView的QCustomPlot 全网唯一份
  • Fast Planner规划算法(一)—— Fast Planner前端
  • 问题记录-SpringBoot 2.7.2 整合 Swagger 报错
  • 【视觉SLAM】 十四讲ch5习题
  • Webpack基础学习-Day01
  • 如何防止热插拔烧坏单片机
  • JQuery+HTML+JavaScript:实现地图位置选取和地址模糊查询
  • ArcGIS Pro SDK (九)几何 13 多部件