详解nodejs与javascript中的aes加密
来源: 阅读:1706 次 日期:2016-06-25 13:14:55
温馨提示: 小编为您整理了“详解nodejs与javascript中的aes加密”,方便广大网友查阅!

这篇文章主要为大家详细介绍了nodejs与javascript中aes加密的相关资料,感兴趣的朋友可以参考一下

一、简介

1.aes加密简单来说,在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。高级加密标准已然成为对称密钥加密中最流行的算法之一。

2.AES的区块长度固定为128 比特,密钥长度则可以是128,192或256比特;而Rijndael使用的密钥和区块长度可以是32位的整数倍,以128位为下限,256比特为上限。包括AES-ECB,AES-CBC,AES-CTR,AES-OFB,AES-CFB。

3.在这里我们只接受常用的ECB方式 + pkcs7padding(与pkcs5padding值相同)填充加密。 

二、应用

1.nodejs中aes的使用

var crypto = require('crypto');

var aesutil = module.exports = {};

/**

 * aes加密

 * @param data 待加密内容

 * @param key 必须为32位私钥

 * @returns {string}

 */

aesutil.encryption = function (data, key, iv) {

 iv = iv || "";

 var clearEncoding = 'utf8';

 var cipherEncoding = 'base64';

 var cipherChunks = [];

 var cipher = crypto.createCipheriv('aes-256-ecb', key, iv);

 cipher.setAutoPadding(true);

 cipherChunks.push(cipher.update(data, clearEncoding, cipherEncoding));

 cipherChunks.push(cipher.final(cipherEncoding));

 return cipherChunks.join('');

}

/**

 * aes解密

 * @param data 待解密内容

 * @param key 必须为32位私钥

 * @returns {string}

 */

aesutil.decryption = function (data, key, iv) {

 if (!data) {

  return "";

 }

 iv = iv || "";

 var clearEncoding = 'utf8';

 var cipherEncoding = 'base64';

 var cipherChunks = [];

 var decipher = crypto.createDecipheriv('aes-256-ecb', key, iv);

 decipher.setAutoPadding(true);

 cipherChunks.push(decipher.update(data, cipherEncoding, clearEncoding));

 cipherChunks.push(decipher.final(clearEncoding));

 return cipherChunks.join('');

}

2.javascript中aes的使用

下载第三方库Crypto-js.js git地址:https://github.com/brix/crypto-js

引入src下的crypto-js.js,加密代码如下:

var key = "12345678"  //秘钥必须为:8/16/32位

var message = "123456";

//加密

var encrypt = CryptoJS.AES.encrypt(message, CryptoJS.enc.Utf8.parse(key), {

 mode: CryptoJS.mode.ECB,

 padding: CryptoJS.pad.Pkcs7

});

console.log("value: "+encrypt);

//解密

var decrypt = CryptoJS.AES.decrypt(encrypt, CryptoJS.enc.Utf8.parse(key), {

 mode: CryptoJS.mode.ECB,

 padding: CryptoJS.pad.Pkcs7

});

console.log("value: "+decrypt.toString(CryptoJS.enc.Utf8));

以上就是本文的全部内容,希望对大家的学习有所帮助。

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map