node-rsa使用

简单介绍使用node-rsa模块生成/导出秘钥,加密/解密,签名/验证

具体方法见API

1.首先导入模块:

npm install node-rsa

2.生成,导入导出秘钥

var NodeRSA = require('node-rsa');

var key = new NodeRSA({b: 512});//生成512位秘钥
var pubkey = key.exportKey('pkcs8-public');//导出公钥
var prikey = key.exportKey('pkcs8-private');//导出私钥
var pubKey = new NodeRSA(pubKey,'pkcs8-public');//导入公钥
var priKey = new NodeRSA(priKey,'pkcs8-private');//导入私钥

3.加密解密

公钥加密(返回密文):

pubKey = new NodeRSA(publicKey,'pkcs8-public');
var encrypted = pubKey.encrypt(buffer, 'base64');

私钥解密(返回明文):

priKey = new NodeRSA(privateKey,'pkcs8-private');
var decrypted = priKey.decrypt(buffer, 'utf8');

4.签名验证

私钥签名(返回签名):

priKey = new NodeRSA(privateKey,'pkcs8-private');
var signature = priKey.sign(buffer);

公钥验证(返回true或false):

pubKey = new NodeRSA(publicKey,'pkcs8-public');
var flag = pubKey.verify(buffer, signature);
上面只是一种实现方法,其中这些方法中可能还有一些其他参数选项,详细参考官方的api

你可能感兴趣的:(nodejs)