提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
在JavaScript中,可以使用RSA算法实现数据的加密和解密。
下载链接:https://download.csdn.net/download/weixin_48839391/89744087
一、RSA概述
RSA 是一种非对称加密算法,使用一对密钥:公钥 和 私钥。
公钥加密:任何人可以使用公钥加密信息。
私钥解密:只有拥有私钥的人才能解密加密的信息。
私钥签名:私钥可以用于对消息进行签名。
公钥验证签名:任何人都可以用公钥验证签名的真实性。
二、JavaScript实现 RSA加密和解密
1.安装 node-forge 库
npm install node-forge
2.方法封装
3.实现
代码:
const RSACrypto = require('./rsa-crypto');
const rsa = new RSACrypto();
// 1. 生成密钥对
rsa.generateKeys();
// 2. 加密
const message = "Hello World!";
const encryptedMessage = rsa.encryptMessage(message);
console.log("Encrypted:", encryptedMessage);
// 3. 解密
const decryptedMessage = rsa.decryptMessage(encryptedMessage);
console.log("Decrypted:", decryptedMessage);
结果:
RSA密钥对已生成并保存到文件中。
Encrypted: Wv7IAeWhNxnl/teAeGxpK86WaDTc7XvOQmt9vydpnqs6PCFa9VG4cYiK6cLDKLIV8QCSgd7ua5XHCS1SRRZeeJNdallcqLz86l3oLgiDNFeC5PpPKyB+BO0mlvggoagrcJroZtcHuFR/c6tNzFwuLExCLwujZACHsl3RQlCae86ZTts+h/x00NkAThwlQwXMZZ4AyE6dyGudrjNyJjnQs7RYIt
rkuSivve0sfpRkQPfh8xik6VtOudS8BnK8s4fNCNujDcQ95UCXB1nPzxEdaDFS+5UENQo9pVQUcZpb4bWu77nGkfGh2bhMSPhFGqTug6kbOh21dwtnlbMGwZUfFw==
Decrypted: Hello World!
三、总结
通过这个封装好的 rsa-crypto.js 文件,所有与RSA加密和解密相关的操作(密钥生成、密钥存储、加密、解密)都被整理为独立的功能模块。你可以将公私钥保存到文件中,也可以从文件加载公私钥进行加密和解密。