小程序模板網(wǎng)

【小程序】RSA簽名

發(fā)布時間:2017-12-15 09:13 所屬欄目:小程序開發(fā)教程

title: 【小程序】RSA簽名type: categoriesdate: 2017-05-27 17:01:15categories: 小程序tags: 一個適用于微信小程序的RSA簽名庫。RSA簽名的小程序DEMO:https://github.com/zhangzhaopds/WeixinApp_RSA_Signature.g ...

 
 
 

title: 【小程序】RSA簽名 
type: categories 
date: 2017-05-27 17:01:15 
categories: 小程序

tags: [RSA, 簽名]

一個適用于微信小程序的RSA簽名庫。

RSA簽名的小程序DEMO:https://github.com/zhangzhaopds/WeixinApp_RSA_Signature.git

使用

1、引入文件

var RSA = require('../../utils/wx_rsa_signature.js')
  • 1
  • 1

2、調(diào)用

var privateKey_pkcs1 = '-----BEGIN RSA PRIVATE KEY-----MIICXQIBAAKBgQC*WKdggwBOtteLL5sPom8RYCjuw0hy6R1jH39tCaep1Dns02bi4CYHk2dSR / 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-----MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC*WKdggwBOtteLL5sPom8RYCjuw0hy6R1jH39tCaep1Dns02bi4CYHk2dSR / t0ABgF5pHYeMxHa74Dp6Z6SjfAKMUu53BbTR615ehK + 03BjtzJzviTF1/ NtLmGaR3aawrDp7oQgq33dfIYbWLuAMkHNiWaoXaGyHh3a8jS2vxfQIDAQAB-----END PUBLIC KEY-----'

    var rsa = new RSA.RSAKey(); // 新建RSA對象
    rsa = RSA.KEYUTIL.getKey(privateKey_pkcs1); // 設置私鑰
    console.log(rsa)
    var hashAlg = 'sha1'; // 設置sha1 sha256
    var hSig = rsa.signString("signData", hashAlg); // 加簽

    var verify = new RSA.RSAKey();
    verify = RSA.KEYUTIL.getKey(publicKey_pkcs1);
    var ver = verify.verifyString("signData", hSig) // 驗簽
    console.log(ver)

    hSig = RSA.hex2b64(hSig); // hex 轉(zhuǎn) b64
    console.log("簽名結(jié)果:" + hSig)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

需要注意的是:區(qū)分RSA私鑰的類型,有pkcs1和pkcs8。pkcs8格式的私鑰主要用于Java中。

// pkcs1格式:
-----BEGIN RSA PRIVATE KEY-----
-----END RSA PRIVATE KEY------

// pkcs8格式:
-----BEGIN PRIVATE KEY-----
-----END PRIVATE KEY-----


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開源 碼云倉庫:starfork
本文地址:http://22321a.com/wxmini/doc/course/18177.html 復制鏈接 如需定制請聯(lián)系易優(yōu)客服咨詢:800182392 點擊咨詢
QQ在線咨詢