最新要闻
- 环球观速讯丨肝帝玩家!《暗黑破坏神4》公测玩家达成全职业满级
- 男子高速奇葩操作:头上竟然套了一个“车顶”
- 热点评!股票除权日在什么时候
- 环球观焦点:阿什莉动捕演员庆祝《生化危机4:重制版》发售 身穿黑丝超吸睛
- 今日精选:网络爽文改编 《赘婿》动画定档4月23日B站开播
- 全球球精选!加拿大旅游团费_加拿大旅游费用
- 小米顶级自研技术!Redmi Note 12 Turbo用上小米影像大脑
- 【新视野】GPT已长出眼睛耳朵 周鸿祎:人工智能将会产生意识
- 看点:苏州天使母基金合作子基金接连完成投资
- 曹德旺谈人工智能:能做饭吃吗?如果大家都去研究会饿死
- 当前看点!南方新一轮强降雨将上线!北方大部气温“狂飙” 最高飙到25度
- 今日观点!12款随便挑 太平鸟印花T恤清仓:到手69元
- 全球观热点:苹果WWDC 2023日期曝光!iOS 17首秀来了:或不再支持iPhone X/8
- 广东突降冰雹 多车被砸毁容!保险给赔吗?
- 事关出生证明、免税购物、高铁新路线!4月一大波新规来了
- 精选!AMD新一代APU曝光:大小核架构终于上了
广告
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
AES之CryptoJS加密与C#解密
(资料图片仅供参考)
曾经以为ChatGpt 应该是无所不知道,无所不能的,但是就这个C# 解密用了两天时间来搞,gpt给的代码一直有各种bug,最后还是要靠搜索引擎Bing的帮助才找到了答案AES加密之CryptoJS与Java C#互相加密解密_梁金堂的博客-CSDN博客这个文章提供了我查找的方向Port crypto-js AES functions to C# - TruongTX Blog这个文章给了我解决的方案下面是完整的代码示例////// /// 待解密的 Base64 字符串 /// 口令,用于生成 Key 和 IV ///C# 版本的 cryptojs.AES.decrypt(encryptedString, passphrase).toString(cryptojs.enc.Utf8) ///使用 AES 加密时,需要传入一个 Key 和一个随机的 IV - 初始化向量(IV 用于为加密过程添加随机性) ///在 crypto-js 中,如果你将一个口令传递给 "encrypt" 函数,例如 ///cryptojs.AES.encrypt(message, passphrase).toString()
,Key 和 IV 将会自动生成为了从口令中派生出 Key,它使用 OpenSSL 兼容的派生函数 EVP_BytesToKey。该模式生成一个新的 8 字节随机 salt,并与口令一起使用来生成 Key 和 IV。更多信息请参见 ///。 使用 ///cryptojs.AES.encrypt(message, passphrase).toString()
加密的结果是一个 Base64 编码的密文,其中包含字符串 "Salted__",后面跟着 8 字节的 salt 和实际的密文。这意味着,前 8 个字节是 "Salted__" 字符串,接下来的 8 个字节是 salt,剩下的字节是实际的密文。以下是解密 cryptojs 生成的 Base64 字符串的步骤: ///- 将 Base64 字符串转换回一个字节数组 ///- 忽略前 8 个字节(为字符串 "Salted__") ///- 取接下来的 8 个字节作为 salt ///- 取剩下的字节作为密文 ///- 使用实用程序函数 ///生成 Key 和 IV - 将密文、Key 和 IV 输入 AES 解密器以获得最终的字符串 ///解密后的字符串 public static string Cryptojs_AesDecrypt(string encryptedString, string passphrase) { // 检查参数是否为 null 或空字符串 if (string.IsNullOrEmpty(encryptedString)) { throw new ArgumentException("加密字符串不能为空。", nameof(encryptedString)); } if (string.IsNullOrEmpty(passphrase)) { throw new ArgumentException("口令不能为空。", nameof(passphrase)); } // 将 Base64 编码的字符串转换为字节数组 var encryptedBytes = Convert.FromBase64String(encryptedString); // 获取盐值和密文 var salt = encryptedBytes[8..16]; var cipherText = encryptedBytes[16..]; // 从口令和盐值派生密钥和 IV const int iterations = 1; // CryptoJS 默认使用 1 次迭代 var passphraseBytes = Encoding.UTF8.GetBytes(passphrase); DeriveKeyAndIv(passphraseBytes, salt, iterations, out var key, out var iv); // 创建 AES 解密器 using var aes = Aes.Create(); aes.Key = key; aes.IV = iv; aes.KeySize = 256; aes.Padding = PaddingMode.PKCS7; aes.Mode = CipherMode.CBC; // 创建解密器 var decryptor = aes.CreateDecryptor(key, iv); // 解密密文 using var msDecrypt = new MemoryStream(cipherText); using var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Read); using var srDecrypt = new StreamReader(csDecrypt); // 从解密流中读取解密后的字节,并将它们放入一个字符串中。 return srDecrypt.ReadToEnd(); } ////// /// 口令字节数组 /// 盐字节数组 /// 哈希迭代次数 /// 输出32字节密钥 /// 输出16字节初始化向量(IV) private static void DeriveKeyAndIv(byte[] passphrase, byte[] salt, int iterations, out byte[] key, out byte[] iv) { // 用于保存哈希值 var hashList = new List使用C#编写等效的OpenSSL EVP_BytesToKey方法 ///从输入的口令和盐生成密钥和初始化向量(IV) ///(); // 计算第一个哈希值 var preHashLength = passphrase.Length + (salt?.Length ?? 0); var preHash = new byte[preHashLength]; // 将口令复制到 preHash 数组 Buffer.BlockCopy(passphrase, 0, preHash, 0, passphrase.Length); if (salt != null) { // 将盐值复制到 preHash 数组 Buffer.BlockCopy(salt, 0, preHash, passphrase.Length, salt.Length); } // 创建 MD5 哈希对象 var hash = MD5.Create(); // 计算哈希值 var currentHash = hash.ComputeHash(preHash); // 迭代计算哈希值 for (var i = 1; i < iterations; i++) { currentHash = hash.ComputeHash(currentHash); } // 将第一个哈希值加入哈希值列表 hashList.AddRange(currentHash); #region 用于32字节密钥和16字节IV // 如果哈希值不足48字节,则进行更多的哈希计算 while (hashList.Count < 48) { preHashLength = currentHash.Length + passphrase.Length + (salt?.Length ?? 0); preHash = new byte[preHashLength]; // 将上一次的哈希值复制到 preHash 数组 Buffer.BlockCopy(currentHash, 0, preHash, 0, currentHash.Length); // 将口令复制到 preHash 数组 Buffer.BlockCopy(passphrase, 0, preHash, currentHash.Length, passphrase.Length); if (salt != null) { // 将盐值复制到 preHash 数组 Buffer.BlockCopy(salt, 0, preHash, currentHash.Length + passphrase.Length, salt.Length); } // 计算哈希值 currentHash = hash.ComputeHash(preHash); // 迭代计算哈希值 for (var i = 1; i < iterations; i++) { currentHash = hash.ComputeHash(currentHash); } // 将计算得到的哈希值加入哈希值列表 hashList.AddRange(currentHash); } #endregion 用于32字节密钥和16字节IV #region 从哈希值列表中提取密钥和 IV // 清除哈希对象 hash.Clear(); // 用于保存密钥的字节数组 key = new byte[32]; // 用于保存 IV 的字节数组 iv = new byte[16]; // 将前32个字节复制到密钥数组 hashList.CopyTo(0, key, 0, 32); // 将后16个字节复制到 IV 数组 hashList.CopyTo(32, iv, 0, 16); #endregion 从哈希值列表中提取密钥和 IV }
关键词:
-
微速讯:Qt源码阅读(二) moveToThread
Qt源码分析之moveToThread这一次,我们来看Qt中关于将一个QObject对象移动至一个线程的函数moveToThread...
来源: 今日快看!简单部署halo博客
微速讯:Qt源码阅读(二) moveToThread
AES之CryptoJS加密与C#解密
环球观速讯丨肝帝玩家!《暗黑破坏神4》公测玩家达成全职业满级
男子高速奇葩操作:头上竟然套了一个“车顶”
热点评!股票除权日在什么时候
【环球新视野】软件测试--详细判断电话号码
前端设计模式——计算属性模式
世界速递!PLG SaaS 案例:如何实践外链自动增长策略?
需求分析报告(软件项目)
每日播报!Android中常见的线程池
环球观焦点:阿什莉动捕演员庆祝《生化危机4:重制版》发售 身穿黑丝超吸睛
今日精选:网络爽文改编 《赘婿》动画定档4月23日B站开播
全球球精选!加拿大旅游团费_加拿大旅游费用
小米顶级自研技术!Redmi Note 12 Turbo用上小米影像大脑
世界观点:.NET6+Quartz实现定时任务
当前观察:logback的使用和原理
【新视野】GPT已长出眼睛耳朵 周鸿祎:人工智能将会产生意识
环球看热讯:状态观测器(一)
看点:苏州天使母基金合作子基金接连完成投资
曹德旺谈人工智能:能做饭吃吗?如果大家都去研究会饿死
当前看点!南方新一轮强降雨将上线!北方大部气温“狂飙” 最高飙到25度
今日观点!12款随便挑 太平鸟印花T恤清仓:到手69元
全球观热点:苹果WWDC 2023日期曝光!iOS 17首秀来了:或不再支持iPhone X/8
广东突降冰雹 多车被砸毁容!保险给赔吗?
事关出生证明、免税购物、高铁新路线!4月一大波新规来了
精选!AMD新一代APU曝光:大小核架构终于上了
动态:我国首次实现固态氢能发电并网,“绿电”与“绿氢”灵活转换
易烊千玺代言!九号电动两轮车国内出货突破150万辆
转型电动化 韩系车在中国还有救吗?
老人故意推倒摩托车案胜诉 老人儿子需赔1.6万!车主回应
全球关注:读Java性能权威指南(第2版)笔记28_线程和同步性能中
速讯:孤芳自赏是哪一期蒙面唱将
【全球热闻】“韩国宾利”能拿下中国人吗?
焦点观察:票房破40亿中国影史第10!《流浪地球2》4月14日上线咪咕视频
焦点快看:叙利亚外交部谴责美国对叙发动敌对行动
使用 Linux dd 命令测试磁盘读写性能
国际短信平台接口调用的方法步骤,简单5步快速教程
全球信息:Java之大数加减乘除——构建类
张译包场张颂文的新电影《不止不休》!猫眼评分9.3分
世界快消息!2026年亚运会将不建设运动员村:为了削减开支
焦点资讯:3年来最盛大红毯叫停:邓超激动得像买票进场 胡歌刘亦菲杨幂同框梦回仙剑
当前速看:国内这些城市地标为地球熄灯一小时:有你认识的吗?
小米OPPO和vivo实现突破性跨越!微信聊天记录能互相迁移了
天天微资讯!武汉一小伙考研出分后失眠多日,医生支招制定减压计划
linux中conda虚拟环境使用(便于项目切换)、pip和conda换源
原来熊猫的笑声这么粗犷吗 网友直呼没想到:公鸭嗓笑的像反派
天天讯息:被马斯克16亿垄断的工艺 卡了下游企业的脖子
天天热点评!女孩穿汉服乘公交:颜值惊艳众人
环球视点!液体钙和钙片哪个更容易吸收(液体钙和钙片哪个更好吸收)
python 使用 kafka
世界观点:《暗黑4》与《暗黑3》角色截图对比:女性角色更逼真了
捐100亿建大学 曹德旺:我赚了很多钱但不贪婪 会还给社会
女子摔跤上牙磕进嘴唇1月后才发现 医生惊叹不已:网友直呼心太大
徕卡+双长焦史无前例!小米13 Ultra曝光
焦点信息:Vue——initState【十】
当前信息:国外短信平台收不到验证码,怎么解决?
今日快看!什么叫针灸师
全球热文:红心番石榴吃法?
130余年老字号 非遗工艺 吴裕泰特种级茉莉香毫100g装40元
热资讯!灵隐寺旁小溪中大量放生乌龟死亡被吐槽是伪善 放生已成产业链最高2000元一次
【独家焦点】干旱缓解 新疆最大湖泊变了:阿雅克库木湖30年面积扩大近7成
焦点速讯:WPF 入门基础
周鸿祎与库克共话科技未来:惟一被淘汰的是不会用GPT的人
天天观点:12小时保温保冷 朴原良品316不锈钢保温杯16.9元起
世界快讯:代码漏洞暴露用户支付信息 ChatGPT安全存隐患:官方致歉
世界速讯:聚焦险企负债成本管理 监管座谈会释放调整信号
AMD Yes!Zen4回归骨折价 12核锐龙9 7900到手2549元
学生党福音 Redmi小金刚Note 12 Turbo的NFC卡升级:两大功能合体
当前资讯!mp3格式转换器哪个好_mp3格式转换器
dotnet-csharp
焦点精选!C++ sizeof与strlen,并借此明晰内存对齐
女生靠摆地摊还清百万负债 还有人两周赚1万5、月入万元:摆摊真这么赚钱?
【天天速看料】周鸿祎:中国与GPT-4差距两三年 不存在难以逾越技术障碍
当前热文:Windows OpenGL ES 图像 GPUImageAmatorkaFilter
javascript的基础知识
小彭汽车向小鹏汽车道歉:盘点那些神级模仿的老年代步车
【速看料】《三体》动画今日正式完结!豆瓣评分仅3.8:半数一星差评
焦点关注:998的比亚迪秦PLUS DM-i多能跑?博主极端工况实测:合资还怎么打
当前关注:Office2019永久激活工具_Office2019激活工具神龙版v2023.2
天天快播:What is static and dynamic libraries
[白嫖系列] 白嫖一个永久免费的eu.org域名
速看:76人攻防俱佳夺冠有望,湖人防守第一进攻拉胯,勇士卫冕基本无望
全球新资讯:女子模仿网红穿搭遭对方粉丝网暴!法院判网红连续15天道歉、赔偿
男子喝红牛味道不对发现是累牛引热议:康帅傅、雷碧等山寨货为何层出不穷
资讯推荐:关于aws-s3-bucket-静态网站托管相关的查询-S3.Client.get_bucket_website(**kwargs)
天天速读:西班牙经济连续两年增速达5.5%
用4年不卡!Redmi Note 12 Turbo配置公布:16GB+1TB、5000mAh
环球今头条!男子抖音晒夜爬泰山到井盖下躲风 景区回应:核实后会处罚
【焦点热闻】YCSB工具原理重点内容解读(二)
CSS鼠标样式(cursor)总结(转载)
每日速看!因航班延误缺考复试 考研生崩溃大哭:对不起父母 对不起自己的努力
猪肉含量≥85% 一口全是肉:亚明猪肉烤肠29.9元2斤大促
越秀资本03月24日获深股通增持98.52万股
精选!宏基e1471g怎么样
热文:czide-CALLAN自制语言(python)
环球短讯!《安富莱嵌入式周报》第307期:开源智能制冷板,Keil MDK6发布时间,编程助手Github Copilot X,Matlab2023,高品质电容
英特尔联合创始人戈登·摩尔去世:享年94岁 “摩尔定律”提出者
天天热点!公司回应招聘前台要求身材 硬性要求臀围86腰围58:网友吐槽离谱
每日消息!学习 React 需要具备的 JavaScript 知识