1、生成公钥、并根据公钥生成私钥
jsencrypt: http://travistidwell.com/jsencrypt/
私钥:
openssl genrsa -out rsa_1024_priv.pem 1024
//1024可能过大(JSEncrypt会返回false),可改成512
openssl genrsa -out rsa_1024_priv.pem 512
根据私钥生成公钥:
openssl rsa -pubout -in rsa_1024_priv.pem -out rsa_1024_pub.pem
2、前端加密
var crypt = new JSEncrypt();
crypt.setKey(__YOUR_OPENSSL_PRIVATE_OR_PUBLIC_KEY__);
var text = 'test';
//密文
var enc = crypt.encrypt(text);
3、node-rsa解密:https://www.npmjs.com/package/node-rsa
参考:https://www.jb51.net/article/148699.htm
const NodeRsa = require('node-rsa')
let privateKey = fs.readFileSync('./123.txt', 'utf8')
let rsa = new NodeRsa(privateKey)
rsa.setOptions({encryptionScheme: 'pkcs1'});
//明文
let pwd = rsa.decrypt(ctx.request.body.pwd, 'utf8')