原文链接:https://www.cnblogs.com/JCcccit/p/16868137.html
前言
最近项目组开始关注一些敏感数据的明文相关的事宜 , 其实这些东西也是都有非常成熟的解决方案。 既然最近着手去解决这些事情,那么也顺便给还未了解的大伙普及一下。Springboot yml配置参数数据加密 (数据加密篇 一)_默默不代表沉默-CSDN博客_springboot接口加密
Springboot AOP实现指定敏感字段数据加密 (数据加密篇 二)_默默不代表沉默-CSDN博客
【资料图】
Springboot 使用mysql加密解密函数 (数据加密篇 三)_默默不代表沉默-CSDN博客
这三篇其实已经输出了,但是其实真正落地的时候,我考虑到加密算法的问题,我自己还是做了些许调整。
正文
我配置文件里面写的参数是用的我们自己统一指定的加密算法,
所以解密的时候使用默认jasypt的解密是没办法成功的。
这时候我们就需要自己重写 这个解密配置yml文件参数的解析器了。
话不多说, 我们开始自定义起来。
com.github.ulisesbocchio jasypt-spring-boot-starter 3.0.2
先丢出一个我们自定义选择的加解密工具类 AES的加密解密工具类:
MyEncryptUtil.java
import javax.crypto.Cipher;import javax.crypto.SecretKey;import javax.crypto.spec.GCMParameterSpec;import javax.crypto.spec.SecretKeySpec;import java.util.Base64;/** * @Author JCccc * @Description * @Date 2021/10/29 16:52 */public class MyEncryptUtil { public static String parseByte2HexStr(byte buf[]) { StringBuffer sb = new StringBuffer(); for (int i = 0; i < buf.length; i++) { String hex = Integer.toHexString(buf[i] & 0xFF); if (hex.length() == 1) { hex = "0" + hex; } sb.append(hex.toUpperCase()); } return sb.toString(); } public static byte[] parseHexStr2Byte(String hexStr) { if (hexStr.length() < 1) { return null; } byte[] result = new byte[hexStr.length() / 2]; for (int i = 0; i < hexStr.length() / 2; i++) { int high = Integer.parseInt(hexStr.substring(i * 2, i * 2 + 1), 16); int low = Integer.parseInt(hexStr.substring(i * 2 + 1, i * 2 + 2), 16); result[i] = (byte) (high * 16 + low); } return result; } /** * 1.0 aes-128-gcm 加密 * * @param originalData 为需加密信息 * @param key 32位的16进制key * @return */ public static String encrypt(String originalData, String key) { try { //修改添加字符集 byte[] sSrc = originalData.getBytes("UTF-8"); byte[] sKey = MyEncryptUtil.parseHexStr2Byte(key); SecretKeySpec skeySpec = new SecretKeySpec(sKey, "AES"); Cipher cipher = Cipher.getInstance("AES/GCM/PKCS5Padding"); cipher.init(Cipher.ENCRYPT_MODE, skeySpec); //这边是获取一个随机的iv 默认为12位的 byte[] iv = cipher.getIV(); //执行加密 byte[] encryptData = cipher.doFinal(sSrc); //这边进行拼凑 为 iv + 加密后的内容 byte[] message = new byte[12 + sSrc.length + 16]; System.arraycopy(iv, 0, message, 0, 12); System.arraycopy(encryptData, 0, message, 12, encryptData.length); return Base64.getEncoder().encodeToString(message); } catch (Exception ex) { ex.printStackTrace(); return null; } } /** * 1.0 aes-128-gcm 解密 * * @param encryptData 已加密过的数据 * @param key 32位的16进制key * @return */ public static String decrypt(String encryptData, String key) { try { byte[] sSrc = Base64.getDecoder().decode(encryptData); byte[] sKey = MyEncryptUtil.parseHexStr2Byte(key); GCMParameterSpec iv = new GCMParameterSpec(128, sSrc, 0, 12); Cipher cipher = Cipher.getInstance("AES/GCM/PKCS5Padding"); SecretKey key2 = new SecretKeySpec(sKey, "AES"); cipher.init(Cipher.DECRYPT_MODE, key2, iv); //这边和nodejs不同的一点是 不需要移除后面的16位 byte[] decryptData = cipher.doFinal(sSrc, 12, sSrc.length - 12); return new String(decryptData); } catch (Exception ex) { ex.printStackTrace(); return null; } } }
ok,现在我们使用我们的这个加密工具对一些数据进行加密:
加密后的结果 :
直接替换掉yml配置文件里面的数据:
注意了,既然是自定义,那么我们甚至都不需要遵守jasypt的解析规则,我自己定义了一下
格式 : ENC#+ 加密串
这时候,就到了我们的自定义解析器编码环节了:
Encryptor.java :
import com.ulisesbocchio.jasyptspringboot.EncryptablePropertyResolver;import org.springframework.context.annotation.Bean;import org.springframework.stereotype.Component;/** * @Author JCccc * @Description * @Date 2021/12/14 17:05 */@Componentpublic class Encryptor { @Bean(name="encryptablePropertyResolver") EncryptablePropertyResolver encryptablePropertyResolver(){ return new MyEncryptPropertyResolver(); }}
MyEncryptPropertyResolver.java :
import com.demo.easytest.util.MyEncryptUtil;import com.ulisesbocchio.jasyptspringboot.EncryptablePropertyResolver;import org.springframework.stereotype.Component;/** * @Author JCccc * @Description * @Date 2021/12/14 16:56 */@Componentpublic class MyEncryptPropertyResolver implements EncryptablePropertyResolver { private static final String ENC_PREFIX="ENC#"; @Override public String resolvePropertyValue(String value) { if (value!=null && value.startsWith(ENC_PREFIX)){ String str=value.substring(0, value.indexOf("#")); String result=value.substring(str.length()+1); return MyEncryptUtil.decrypt(result,"551b789c25cfbe731f723eab5906de5c"); } return value; }}
其实说白了就是基于jasypt 框架,我们自己改造了一下加解密算法,但是流程还是用人家的。
到这就已经完成了,如果想看看,可以直接debug,看看这个读取解析:
然后正常跑起来,调用一个mysql查询接口,可以看到解析正常,数据库连接正常:
大家可以自己换成自己指定的加解密函数,因为用我本文这个提供的其实有些小限制。
关键词:
(责任编辑:黄俊飞)推荐内容
- 【报资讯】Springboot yml配置参数加密
- 被《借醋》暖到,“石库门的笑声”让樊婷
- 痛心!他才46岁啊
- 郑州宝龙广场“星河里·唐宫夜宴” 主题
- 《阿黛尔·雨果的故事》中的主角形象,对
- 青海:公立医疗机构单颗常规种植牙总费用
- 天天报道:韩国拟将日本列入出口白名单,
- 【天天热闻】微纪录片|平凡世界里的读书
- 恭喜!中国网球第1美女公布恋情,31岁觅
- 每日速看!你只管逛得开心,其他交给经开!
- 全球观天下!辽宁省锦州市2023-04-23 12
- 西游记白龙马歌词_西游记白龙马歌词?
- 短讯!首旅集团与湖北文旅集团达成战略合
- 承德市扎实推进“民营企业服务月、公共服
- 中建八局二公司广东公司开展“辉煌四十年
- 龙生九子貔貅的传说_龙生九子貔貅-世界头
- 拉姆·查兰:没有人才,业绩便无从谈起
- 车辆限速限行!济南绕城高速公路遥墙机场
- 智领时代国际管理咨询 北京有限公司_对
- 小黄人原视频 小黄人短片全集
- 邯郸三中特长生招生简章_邯郸三中
- 有效投资为高质量发展添动力 消息
- 贵阳、昆明、南宁作为西南地区三座省会城
- 马上评|要读懂公众对金庸图书馆去留的关
- 天津机场坐机场大巴到天津站要多少时间能
- 国际经济与贸易专业就业方向是什么(国际
- 吉林推动新能源产业集群成势
- 仿生种子机器人可监测土壤环境,能改变形
- 淄博楼市明显回暖:一季度新建商品住宅网
- 【焦点热闻】玉米百合的种植方法 玉米百
- 网红“竹筒奶茶”被爆有霉斑 探访:卫生
- 广场散步被铁丝绊倒摔伤,谁之过?
- 观察:第二届中国(武汉)文化旅游博览会
- 宝山区3家企业成功获评上海市企业健康促
- 四川省什邡市市场监管局组织开展知识产权
- 科教融合 科创属性 创新生态 市场导向
- 拉波-埃尔坎点赞记者批评阿莱格里的推文
- 世界最资讯丨超市理货员绩效考核表(超市
- 寻人启事怎么写_如何写寻人启示|世界速读
- 横扫!第一支晋级球队!0罚球轰下37分!
- 世界播报:正天丸说明书大全_正天丸说明书
- 电话号码归属地查询软件|全球实时
- python-异常处理和错误调试-asyncio中的
- 当前讯息:海纳:在被美因茨扳平比分后,
- 你说到底为什么都是我的错什么歌表情包_
- 英雄无名_关于英雄无名的简介|热文
- 健身房器械名称大全图片大全(健身房器械
- 孔磊磊
- 天天动态:南京公交车血案_南京公交车
- 时讯:八方宾朋齐聚江城共襄盛会
- 今日关注:安徽“双创汇”活动走进安庆桐
- 我愿你是姑娘从未红杏出墙是什么歌_我愿
- 直击上海车展首个公众日:国产新能源车流
- 和面机结构图片_和面机结构图|头条
- 第14届松花湖开江鱼美食节系列活动将办
- 中期协副秘书长冉丽:发挥期货市场服务乡
- 牙疼消炎药有哪些比较好_治肺炎最好的消
- 天天快消息!康诺邦健康产品有限公司
- 如何在 300 度下慢烤火鸡
- 湘台青年以赛促学 传承中华优秀传统文化
- 邯郸三中特长生招生简章_邯郸三中
- 有效投资为高质量发展添动力 消息
- 贵阳、昆明、南宁作为西南地区三座省会城
- 马上评|要读懂公众对金庸图书馆去留的关
- 天津机场坐机场大巴到天津站要多少时间能
- 国际经济与贸易专业就业方向是什么(国际
- 吉林推动新能源产业集群成势
- 仿生种子机器人可监测土壤环境,能改变形
- 淄博楼市明显回暖:一季度新建商品住宅网
- 【焦点热闻】玉米百合的种植方法 玉米百
- 网红“竹筒奶茶”被爆有霉斑 探访:卫生
- 广场散步被铁丝绊倒摔伤,谁之过?
- 观察:第二届中国(武汉)文化旅游博览会
- 宝山区3家企业成功获评上海市企业健康促
- 四川省什邡市市场监管局组织开展知识产权
- 科教融合 科创属性 创新生态 市场导向
- 拉波-埃尔坎点赞记者批评阿莱格里的推文
- 世界最资讯丨超市理货员绩效考核表(超市
- 寻人启事怎么写_如何写寻人启示|世界速读
- 横扫!第一支晋级球队!0罚球轰下37分!
- 世界播报:正天丸说明书大全_正天丸说明书
- 电话号码归属地查询软件|全球实时
- python-异常处理和错误调试-asyncio中的
- 当前讯息:海纳:在被美因茨扳平比分后,
- 你说到底为什么都是我的错什么歌表情包_
- 英雄无名_关于英雄无名的简介|热文
- 健身房器械名称大全图片大全(健身房器械
- 孔磊磊
- 天天动态:南京公交车血案_南京公交车
- 时讯:八方宾朋齐聚江城共襄盛会
- 今日关注:安徽“双创汇”活动走进安庆桐
- 我愿你是姑娘从未红杏出墙是什么歌_我愿
- 直击上海车展首个公众日:国产新能源车流
- 和面机结构图片_和面机结构图|头条
- 第14届松花湖开江鱼美食节系列活动将办
- 中期协副秘书长冉丽:发挥期货市场服务乡
- 牙疼消炎药有哪些比较好_治肺炎最好的消
- 天天快消息!康诺邦健康产品有限公司
- 如何在 300 度下慢烤火鸡
- 湘台青年以赛促学 传承中华优秀传统文化
- 中国肉牛产业发展大会在湖北枝江举行-今
- 即日起成都启动一批电子警察抓拍设备 具
- 最新消息:做代购怎么起步朋友圈_做代购
- 洪湖市气象台发布雷电黄色预警【III级/较
- 当前要闻:千锤万凿出深山烈火焚烧若等闲
- 徭役是什么意思怎么读 徭役是什么意思|
- 当缤纷地球遇见绝美中国色
- 拟声词三个字的词语有哪些_拟声词大全三
- 世界动态:奇葩父女情“毁三观”?父女亲
- 恭喜!足协紧急官宣:2队获递补资格,高
- 避孕套哪个牌子好清理-避孕套哪个牌子好
- 【快播报】广西壮族自治区桂林市2023-04-
- 世界读书日丨作家钟法权荐读:《静静的顿
- 世界热议:大宋武林群豪在何处袭击萧远山
- AI生成艺术:虚拟画笔下新艺术视界的探讨
- 美尚生态造假案波及 广发证券遭立案调查
- 天天热点评!龙星化工董秘回复:公司经营
- 美职联辛辛那提FCvs波特兰伐木工比分预测
- 达美乐披萨为啥在中国干不过必胜客? 全
- “西强东弱”最明显的一个赛季!最佳一阵