返回首页
当前位置: 主页 > 网络编程 > Jsp实例教程 >

nodejs常用4中加密方式详解

时间:2016-11-02 20:19来源:知行网www.zhixing123.cn 编辑:麦田守望者

/**
* @加密模块
* @md5可以被彩虹表破解,这里就不用啦
* */
//导入模块

var crypto = require('crypto');  

/**
* @aes192加密模块
* @param str string 要加密的字符串
* @param secret string 要使用的加密密钥(要记住,不然就解不了密啦)
* @retrun string 加密后的字符串
* */

exports.getEncAse192 = function(str, secret) {  
    var cipher = crypto.createCipher("aes192", secret); //设置加密类型 和 要使用的加密密钥  
    var enc = cipher.update(str, "utf8", "hex");    //编码方式从utf-8转为hex;   
    enc += cipher.final("hex"); //编码方式从转为hex;   
    return enc; //返回加密后的字符串  
}    

/**
* @aes192解密模块 * @param str string 要解密的字符串
* @param secret string 要使用的解密密钥(要和密码的加密密钥对应,不然就解不了密啦) * @retrun string 解密后的字符串
* */

exports.getDecAse192 = function(str, secret) {  
    var decipher = crypto.createDecipher("aes192", secret);  
    var dec = decipher.update(str, "hex", "utf8");//编码方式从hex转为utf-8;  
    dec += decipher.final("utf8");//编码方式从utf-8;  
    return dec;  
}  


/** * @Hmac-sha1加密模块 (每次加密随机,不可逆)
* @param str string 要加密的字符串
* @param secret string 要使用的加密密钥
* @retrun string 加密后的字符串
* */

exports.getHmac = function(str, secret) {  
    var buf = crypto.randomBytes(16);
    secret = buf.toString("hex");//密钥加密;
    var Signture = crypto.createHmac("sha1", secret);//定义加密方式
    Signture.update(str);
    var miwen=Signture.digest().toString("base64");//生成的密文后将再次作为明文再通过pbkdf2算法迭代加密;
    return miwen;
}


/**
* @sha1加密模块 (加密固定,不可逆)
* @param str string 要加密的字符串
* @retrun string 加密后的字符串
* */

exports.getSha1 = function(str) {  
    var sha1 = crypto.createHash("sha1");//定义加密方式:md5不可逆,此处的md5可以换成任意hash加密的方法名称;  
    sha1.update(str);  
    var res = sha1.digest("hex");  //加密后的值d  
    return res;  
}  
顶一下
(1)
100%
踩一下
(0)
0%
标签(Tag):nodejs nodejs服务器
------分隔线----------------------------
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:点击我更换图片