您的位置:首页 > Web前端 > Node.js

Node-RSA 验证签名

2015-09-09 12:10 846 查看
/**
 * Created by Bluesky on 2015/9/8.
 */
var crypto = require('crypto');
/**
 * 验证签名
 * @param src_sign 签名源串
 * @param signature 已生成的签名
 * @param public_key 公钥
 * @returns {*}
 */
function verify(src_sign, signature, public_key) {
    // 构造PEM编码
    public_key = insert_str(public_key, '\n', 64);
    public_key = '-----BEGIN PUBLIC KEY-----\n' + public_key + '-----END PUBLIC KEY-----';

    var verifier = crypto.createVerify('RSA-SHA1');
    console.log('验证签名public key:\n' + public_key);
    console.log('验证签名src_sign:' + src_sign);
    verifier.update(new Buffer(src_sign, 'utf-8'));
    return verifier.verify(public_key, signature, 'base64');
}
/**
 * 在指定位置插入字符串
 * @param str
 * @param insert_str
 * @param sn
 * @returns {string}
 */
function insert_str(str, insert_str, sn) {
    var newstr = "";
    for (var i = 0; i < str.length; i += sn) {
        var tmp = str.substring(i, i + sn);
        newstr += tmp + insert_str;
    }
    return newstr;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: