前言

微信小程序在后端进行预付单操作后,由前端调起支付接口,此时需要对参数进行SHA256withRSA签名计算。

计算签名的实现

废话少说,直接看东西

const { KJUR, KEYUTIL } = require('jsrsasign');
const jsr = require('jsrsasign');
// Author Hermit-xx 2023-06-27
function sha256WithRSA(message, privateKey) {
  // 创建 RSAKey 对象
  const rsaKey = KEYUTIL.getKey(privateKey);
  // 进行SHA256withRSA签名
  const signature = new KJUR.crypto.Signature({ alg: 'SHA256withRSA' });
  signature.init(rsaKey);
  signature.updateString(message);
  const signatureHex = signature.sign();
  const signatureBase64 = jsr.hextob64(signatureHex)
  return signatureBase64;
}

module.exports = sha256WithRSA

补充说明

运用以上代码,就可以实现对消息体的SHA256 RSA签名的计算,最后得到的是Base64的数据。
注意:其中privateKey需要将密钥文件完整的传入,包括-----BEGIN PRIVATE KEY----------END PRIVATE KEY-----

Logo

DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。

更多推荐