微信小程序中使用RSA算法生成秘钥对

GitHub 上使用 JavaScript 来生成公钥私钥对的库:https://github.com/travist/jsencrypt/

修改库

但是在微信小程序中,引入这个库会报这样的错误
error.png

原因是这个第三方库使用了 window 对象,而微信小程序的页面的脚本逻辑是在 JsCore 中运行,JsCore 是一个没有窗口对象的环境,所以不能在脚本中使用 window,也无法在脚本中操作组件。

经过了一段时间的挣扎,终于找到了解决方法:

  1. 给第三方库添加 window2 和 navigator2 变量
  2. 将程序中用到 window 和 navigator 的地方进行全局替换 为window2 和 navigator2。
(function (global, factory) {
    typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
    typeof define === 'function' && define.amd ? define(['exports'], factory) :
    (factory((global.JSEncrypt = {})));
}(this, (function (exports) { 'use strict';
//--------------------- 这里开始添加---------------------
  // 用来替换 navigator
  var navigator2 = {
    appName: 'Netscape',
    userAgent: 'Mozilla/5.0 (iPhone; CPU iPhone OS 9_1 like Mac OS X) AppleWebKit/601.1.46 (KHTML, like Gecko) Version/9.0 Mobile/13B143 Safari/601.1'
  };
  //  用来替换window
  var window2 = {
    ASN1: null,
    Base64: null,
    Hex: null,
    crypto: null,
    href: null
  };
//--------------------- 这里结束添加---------------------
var BI_RM = "0123456789abcdefghijklmnopqrstuvwxyz";
function int2char(n) {
    return BI_RM.charAt(n);
}

生成公钥私钥

// 引入文件
var Encrypt = require('jsencrypt.js')

// 生成秘钥对
// 返回数组 array[0]公钥  array[1]私钥
function generateKeys(){
  var crypt = new Encrypt.JSEncrypt({ default_key_size: 1024 });
  crypt.getKey();
  var publicKey = crypt.getPublicKey();
  var privateKey = crypt.getPrivateKey();

  // 去除-----*** RSA **** KEY----- 和空格换行
  publicKey = (publicKey.split('-----'))[2];
  publicKey = publicKey.replace(/\n/g, "").replace(/\r/g, "").replace(/\t/g, "").replace(/\s*/g, "");
  privateKey = (privateKey.split('-----'))[2];
  privateKey = privateKey.replace(/\n/g, "").replace(/\r/g, "").replace(/\t/g, "").replace(/\s*/g, "");

  // 返回生成的秘钥对
  return [publicKey, privateKey];
}

推荐阅读更多精彩内容

  • 原文地址 https://mbinary.coding.me/introduction-to-bitcoin.ht...
    mbinary阅读 4,389评论 0 4
  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    爱运动爱学习阅读 15,683评论 3 114
  • 一、快速术语检索 比特币地址:(例如:1DSrfJdB2AnWaFNgSbv3MZC2m74996JafV)由一串...
    不如假如阅读 15,339评论 6 90
  • 曾有人跟我说:不要一个人在餐厅吃饭,不要一个人去电影院,那样会显得很“悲惨”。我暗自一惊,想象着经常独自一人吃饭、...
    笔尖忆暖阅读 401评论 6 3
  • 在不知不觉中.暮然回首.独自一个人.安然的走过了七年. 一直以为.再也不会遇到.怦然心动的感觉了.和他相识于那个夏...
    小叶鸟阅读 140评论 2 2