node与javascriptAES加密
来源:互联网 发布:群智能算法应用 编辑:程序博客网 时间:2024/06/05 16:06
简介:
1.aes加密简单来说,在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。高级加密标准已然成为对称密钥加密中最流行的算法之一。
2.AES的区块长度固定为128 比特,密钥长度则可以是128,192或256比特;而Rijndael使用的密钥和区块长度可以是32位的整数倍,以128位为下限,256比特为上限。包括AES-ECB,AES-CBC,AES-CTR,AES-OFB,AES-CFB。
具体的加密算法和模式的区别:点击《AES加解密算法的模式介绍》查看。
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));
- node与javascriptAES加密
- koa使用之node.js 文件加密与解密
- node.js HMAC_SHA1加密
- Node crypto crc32 加密
- node中aes加密
- node 的crypto加密
- Node.js 基于 ursa 模块的 RSA 加密解密(已与IOS,Android实现加密通信)
- Node.js 中的加密解密
- node.js MD5加密例程
- node-webkit代码加密保护
- 0009、node 之密码加密
- node.js 的加密功能
- node.js中的加密模块
- aes对称加密 -- node版
- node中的加密模块 crypto
- node.JS md5加密中文与php结果不一致的解决方法
- node.JS md5加密中文与php结果不一致的解决方法
- Node * a 与Node* &a
- Ubuntu下Vue.js+webpack的安装(nodejs版本纠正)
- 面试题目汇总(JAVA算法/数据结构)
- Oracle RAW类型基本操作函数及使用示例
- Echarts之地图自定义lable文本标签&去掉小点
- Centos7安装并配置mysql5.6完美教程
- node与javascriptAES加密
- zabbix
- Linux tty驱动程序<一> 架构
- Deconvolutional network
- CodeIgniter 入门教程第一篇:信息发布
- Android 开发笔记——通过 Intent 传递类对象
- CENTOS7快速入门(一)
- JAVA中sort函数的简单使用方法 (JAVA新手向)
- 专业的Excel C ++ API Aspose.Cells for C++ 发布 | 附下载