依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 34|回复: 0

NODE.JS使用AES加密,在DELPHI7中进行解密

[复制链接] 主动推送

8690

主题

8742

帖子

9805

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
9805
发表于 2024-7-3 16:01:36 | 显示全部楼层 |阅读模式
在Node.js中使用AES加密并在Delphi 7中进行解密涉及几个步骤。由于Delphi 7相对较旧,你可能需要使用一些第三方库或手动实现AES算法。以下是一个简化的示例,展示了如何在Node.js中使用crypto库进行AES加密,并在Delphi 7中使用Indy库(一个流行的网络和安全库)进行解密。
Node.js 加密代码
首先,在Node.js中,你可以使用内置的crypto库进行AES加密。这里是一个简单的示例:
  1. const crypto = require('crypto');
  2. const algorithm = 'aes-256-cbc';
  3. const key = crypto.randomBytes(32); // 使用32字节的密钥(对于AES-256)
  4. const iv = crypto.randomBytes(16); // 初始化向量(IV)对于CBC模式需要16字节

  5. function encrypt(text, key, iv) {
  6.   let cipher = crypto.createCipheriv(algorithm, key, iv);
  7.   let encrypted = cipher.update(text, 'utf8', 'hex');
  8.   encrypted += cipher.final('hex');
  9.   return {
  10.     encryptedText: encrypted,
  11.     key: key.toString('hex'), // 将密钥转换为hex字符串以进行传输
  12.     iv: iv.toString('hex') // 将IV转换为hex字符串以进行传输
  13.   };
  14. }

  15. let textToEncrypt = 'Hello, World!';
  16. let encryptedData = encrypt(textToEncrypt, key, iv);
  17. console.log(encryptedData);
复制代码
Delphi 7 解密代码
在Delphi 7中,你可以使用Indy库(也称为IdHTTPComponents)进行AES解密。首先,你需要下载并安装Indy库到你的Delphi环境中。
以下是一个简化的Delphi 7解密示例,它假设你已经有了加密的文本、密钥和IV(作为hex字符串):
  1. uses
  2.   ..., IdAES, IdCoderMIME, IdGlobal;

  3. function DecryptAES256CBC(const AEncryptedText, AKeyHex, AIVHex: string): string;
  4. var
  5.   AES: TIdAES;
  6.   Decoder: TIdDecoderMIME;
  7.   Key, IV: TIdBytes;
  8.   Decrypted: TIdBytes;
  9. begin
  10.   // 初始化AES解密器
  11.   AES := TIdAES.Create(nil);
  12.   try
  13.     // 将hex字符串转换为字节数组
  14.     Key := IdGlobal.HexToBytes(AKeyHex);
  15.     IV := IdGlobal.HexToBytes(AIVHex);

  16.     // 设置密钥和IV
  17.     AES.Key := Key;
  18.     AES.InitVector := IV;
  19.     AES.Mode := cbcAES;
  20.     AES.Padding := pkcs7;

  21.     // 解密
  22.     Decrypted := AES.DecryptCBC(IdGlobal.StringToBytes(AEncryptedText, IndyTextEncoding_UTF8));

  23.     // 将解密后的字节数组转换为字符串
  24.     Decoder := TIdDecoderMIME.Create(nil);
  25.     try
  26.       Result := Decoder.DecodeBytes(Decrypted, IndyTextEncoding_UTF8);
  27.     finally
  28.       Decoder.Free;
  29.     end;
  30.   finally
  31.     AES.Free;
  32.   end;
  33. end;

  34. // 使用示例
  35. var
  36.   EncryptedText, KeyHex, IVHex: string;
  37.   DecryptedText: string;
  38. begin
  39.   // 这里你应该从某处获取EncryptedText, KeyHex, IVHex的值(可能是从文件、网络或其他地方)
  40.   DecryptedText := DecryptAES256CBC(EncryptedText, KeyHex, IVHex);
  41.   ShowMessage(DecryptedText); // 显示解密后的文本
  42. end;
复制代码
注意
  • 你需要确保在Delphi 7项目中正确地安装了Indy库,并将其包含在你的uses子句中。
  • 这个示例使用了AES-256-CBC模式和PKCS7填充。确保Node.js和Delphi中的设置相匹配。
  • 密钥和IV在Node.js中作为随机字节生成,但在实际应用中,你可能需要一种更安全的方式来管理和共享这些值。
  • 加密和解密过程中使用的字符编码(在这个例子中是UTF-8)应该在两端保持一致。


相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员5折;永久VIP免费
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2024-7-23 22:46

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表