微信小程序使用云函数进行RSA进行加密解密

第一、先安装node.js环境

这里不叙述

第二、创建云函数

会的都会

第三、安装node-rsa

npm install node-rsa

在这里插入图片描述

第四、写代码

// 云函数入口文件
const cloud = require('wx-server-sdk')
const NodeRSA = require('node-rsa');

const publicKey="-----BEGIN PUBLIC KEY-----MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAMshKUYpIewWLODvYfJNHn6oCcsEtvA4F1cweK5anOXMRHzD3pI65S+8nq3QPac9ESvog90UJvsUtLpbMtI68gMCAwEAAQ==-----END PUBLIC KEY-----"
const privateKey="-----BEGIN PRIVATE KEY-----MIIBVQIBADANBgkqhkiG9w0BAQEFAASCAT8wggE7AgEAAkEAyyEpRikh7BYs4O9h8k0efqgJywS28DgXVzB4rlqc5cxEfMPekjrlL7yerdA9pz0RK+iD3RQm+xS0ulsy0jryAwIDAQABAkEAnKmRvKPinsOnjz/wycCCwWp2SxbyxKhuD/e5S7dlBLE6kfJPsOhov+BmVJn0fGlDdbAHuRZqhfAa7wwt2rli8QIhAPSAwmAr7Awqh3xCG1n8OlS5TQGMeEeLWpaXTjD3r667AiEA1K5c9zwAUy05RsK34yJk6vU7J4Hxv5O8CbW3btft6VkCIQDgszhvc84R/D/ZVVOXpjLhTA5WHwcnEQ2mmdT1MZvWIwIgS6OnlJZWVz6iPDRMSg+VbKrC2w4v+D6Ghb2G+3j4OCECIFTV3SYu/djwZWEEdCvyGNvpoilBUFQmdpQLDkvH7VmG-----END PRIVATE KEY-----"

cloud.init()

// 云函数入口函数
exports.main = async (event, context) => {
  const wxContext = cloud.getWXContext()
  // 实例
  const data = { openid: wxContext.OPENID};

  const encrypted = encrypt(data);

  const decrypted = decrypt(encrypted);
  
  return {
    'encrypted': encrypted,
    'decrypted': decrypted
  }
}

// 公钥加密
function encrypt(data) {
  
  const nodersa = new NodeRSA(publicKey);
  // nodersa.setOptions({ encryptionScheme: 'pkcs1' });
  const encrypted = nodersa.encrypt(data, 'base64');
  return encrypted;
}
 
// 私钥解密
function decrypt(data) {
  const nodersa = new NodeRSA(privateKey);
  const decrypted = nodersa.decrypt(data, 'utf8');
  return decrypted;
}
 

下课

微信小程序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. 这种加密方式如何防止中间人攻击?
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值