js rsa验签_微信小程序RSA签名、验签、加密、解密

var privateKey_pkcs1 = '-----BEGIN RSA PRIVATE KEY-----MIICXQIBAAKBgQCk7WKdggwBOtteLL5sPom8RYCjuw0hy6R1jH39tCaep1Dns02bi4CYHk2dSR / t0ABgF5pHYeMxHa74Dp6Z6SjfAKMUu53BbTR615ehK + 03BjtzJzviTF1 / NtLmGaR3aawrDp7oQgq33dfIYbWLuAMkHNiWaoXaGyHh3a8jS2vxfQIDAQABAoGAIKRnLzts + tVWU5ZRfgUGp7 + tzToZSEYQ378VtJ / yQNZmueUQCCgdJH5i6C1v51aSrHIfc99Y4wC3/ 5qNI3M1RlRpIakmcaiEv1m6huDPLKFq6Y1e+ AZ0Cb0xo3bny + VTOvfGgcAdSa6++K47bGaxyKzwGeNZQkltm5sgbVcKvkECQQDVjWbSU8P8nDb+TP5Aqr + DaMVA425wv2ra2jhxd6KqKxgHHB7yYWlODiYNrtALOEG9zfSpHVQWhZpiKq8XcWwRAkEAxbWzPAqZxaZ / XTs65uCL0 + iqif0qCSDUNis61wYm2UwOh4LqBZIFop94B3ybEXbCvUl0v26H0fgXjFUErvlKrQJBAKjbAe5U5accLi + t2WxwlrXlZfME4hKsiGU8H10455n+ MSWOCrpEY + ugLF6tVztH5FOcQlRmKFMWmRf + ACxdNsECQDBjkEKZtZkSbwm6fWgUfSSYRWUQeUFSr52yZuxJrShx3Px9phlG6 + opbY8niCx2DKOXXuObgdJ6DglipYrNqOECQQCndP + zU / jwlvjQzEabKdP05uFc5JV6ySFBQwuoENbEvW3uz + Yz31xDYbrwIzrysVDovlj0ExL6LC + JRvpJmHcN-----END RSA PRIVATE KEY-----'    var publicKey_pkcs1 = '-----BEGIN PUBLIC KEY-----MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCk7WKdggwBOtteLL5sPom8RYCjuw0hy6R1jH39tCaep1Dns02bi4CYHk2dSR / t0ABgF5pHYeMxHa74Dp6Z6SjfAKMUu53BbTR615ehK + 03BjtzJzviTF1/ NtLmGaR3aawrDp7oQgq33dfIYbWLuAMkHNiWaoXaGyHh3a8jS2vxfQIDAQAB-----END PUBLIC KEY-----'    // 加签    var sign_rsa = new RSA.RSAKey();     sign_rsa = RSA.KEYUTIL.getKey(privateKey_pkcs1);     console.log('签名RSA:')    console.log(sign_rsa)    var hashAlg = 'sha1';    var hSig = sign_rsa.signString("signData", hashAlg);     hSig = RSA.hex2b64(hSig); // hex 转 b64    console.log("签名结果:" + hSig)    // 验签    var verify_rsa = new RSA.RSAKey();    verify_rsa = RSA.KEYUTIL.getKey(publicKey_pkcs1);    console.log('验签RSA:')    console.log(verify_rsa)    hSig = RSA.b64tohex(hSig)    var ver = verify_rsa.verifyString("signData", hSig)     console.log('验签结果:' + ver)    // 加密    var encrypt_rsa = new RSA.RSAKey();    encrypt_rsa = RSA.KEYUTIL.getKey(publicKey_pkcs1);    console.log('加密RSA:')    console.log(encrypt_rsa)    var encStr = encrypt_rsa.encrypt('123456')    encStr = RSA.hex2b64(encStr);    console.log("加密结果:" + encStr)    // 解密    var decrypt_rsa = new RSA.RSAKey();    decrypt_rsa = RSA.KEYUTIL.getKey(privateKey_pkcs1);    console.log('解密RSA:')    console.log(decrypt_rsa)    encStr = RSA.b64tohex(encStr)    var decStr = decrypt_rsa.decrypt(encStr)    console.log("解密结果:" + decStr)

微信小程序RSA加密通常用于安全地传输数据,比如API请求的签名验证。Node.js是一个流行的JavaScript运行环境,可以方便地处理这种加密操作。以下是基本流程: 1. **生成公钥和私钥**:在服务器端(Node.js环境中),你需要创建一对公钥和私钥,公钥用于加密私钥用于解密。 ```javascript const crypto = require('crypto'); const { createKeyPair } = crypto; const [publicKey, privateKey] = await createKeyPair('rsa', { modulusLength: 2048, }); ``` 2. **客户端发送数据**:用户在微信小程序发起请求前,会将需要加密的数据和公钥通过HTTPS发送到服务器。 3. **服务器接收并加密**:接收到请求后,服务端用用户的公钥对数据进行加密。 ```javascript const encryptData = async (plaintext, publicKey) => { const buffer = Buffer.from(plaintext, 'utf8'); return crypto.publicEncrypt(publicKey, buffer).toString('base64'); } ``` 4. **服务器解密**:当收到加密数据后,服务器使用私钥进行解密。 ```javascript const decryptData = async (encryptedData, privateKey) => { const buffer = Buffer.from(encryptedData, 'base64'); return crypto.privateDecrypt(privateKey, buffer).toString(); } ``` 5. **验证和返回数据**:服务端解密数据后,检查其有效性(如校验签名),然后返回给用户。 **相关问题**: 1. 如何在微信小程序中获取并使用服务器的公钥? 2. 解密失败的原因可能有哪些? 3. 这种加密方式如何防止中间人攻击?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值