详解nodejs与javascript中的aes加密


Posted in NodeJs onMay 22, 2016

一、简介

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));

原文作者:西安.王磊
原文出处:http://vipstone.cnblogs.com/

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

NodeJs 相关文章推荐
NodeJS 模块开发及发布详解分享
Mar 07 NodeJs
nodejs中简单实现Javascript Promise机制的实例
Dec 06 NodeJs
NodeJS远程代码执行
Aug 28 NodeJs
详解如何在NodeJS项目中优雅的使用ES6
Apr 22 NodeJs
浅谈nodejs中的类定义和继承的套路
Jul 26 NodeJs
nodejs+express搭建多人聊天室步骤
Feb 12 NodeJs
nodeJS服务器的创建和重新启动的实现方法
May 12 NodeJs
NodeJs之word文件生成与解析的实现代码
Apr 01 NodeJs
nodejs分离html文件里面的js和css的方法
Apr 09 NodeJs
nodejs中各种加密算法的实现详解
Jul 11 NodeJs
在NodeJs中使用node-schedule增加定时器任务的方法
Jun 08 NodeJs
NodeJS连接MongoDB数据库时报错的快速解决方法
May 13 #NodeJs
Nodejs获取网络数据并生成Excel表格
Mar 31 #NodeJs
Nodejs学习item【入门手上】
May 05 #NodeJs
NodeJS的Promise的用法解析
May 05 #NodeJs
Windows 系统下设置Nodejs NPM全局路径
Apr 26 #NodeJs
Nodejs Stream 数据流使用手册
Apr 17 #NodeJs
NodeJS创建基础应用并应用模板引擎
Apr 12 #NodeJs
You might like
人族 Terran 魔法与科技
2020/03/14 星际争霸
PHP操作XML作为数据库的类
2010/12/19 PHP
PHP实现把MySQL数据库导出为.sql文件实例(仿PHPMyadmin导出功能)
2014/05/10 PHP
php使用mysqli向数据库添加数据的方法
2015/03/20 PHP
PHP框架Laravel学习心得体会
2015/10/28 PHP
Laravel-添加后台模板AdminLte的实现方法
2019/10/08 PHP
了解一点js的Eval函数
2012/07/26 Javascript
Node.js开发指南中的简单实例(mysql版)
2013/09/17 Javascript
js的onload事件及初始化按钮事件示例代码
2013/09/25 Javascript
使用js Math.random()函数生成n到m间的随机数字
2014/10/09 Javascript
jQuery中appendTo()方法用法实例
2015/01/08 Javascript
深入理解JavaScript系列(44):设计模式之桥接模式详解
2015/03/04 Javascript
举例讲解Node.js中的Writable对象
2015/07/29 Javascript
JavaScript的jQuery库插件的简要开发指南
2015/08/12 Javascript
javascript性能优化之DOM交互操作实例分析
2015/12/12 Javascript
解决iview打包时UglifyJs报错的问题
2018/03/07 Javascript
微信小程序-可移动菜单的实现过程详解
2019/06/24 Javascript
[52:32]完美世界DOTA2联赛PWL S2 Magma vs LBZS 第三场 11.18
2020/11/18 DOTA
[49:58]完美世界DOTA2联赛PWL S3 Magma vs DLG 第一场 12.18
2020/12/19 DOTA
python运行时间的几种方法
2016/06/17 Python
对Python中DataFrame选择某列值为XX的行实例详解
2019/01/29 Python
python递归法解决棋盘分割问题
2019/07/17 Python
前端面试必备之html5的新特性
2017/09/05 HTML / CSS
C面试题
2015/10/08 面试题
教育学习自我评价
2014/02/03 职场文书
幼儿教师培训感言
2014/03/08 职场文书
教师敬业奉献模范事迹材料
2014/05/18 职场文书
学习礼仪心得体会
2014/09/01 职场文书
政风行风评议个人心得体会
2014/10/29 职场文书
商务司机岗位职责
2015/04/10 职场文书
小学生安全教育主题班会
2015/08/12 职场文书
公务员学习中国梦心得体会
2016/01/05 职场文书
MySQL 那些常见的错误设计规范,你都知道吗
2021/07/16 MySQL
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
2022/03/03 Python
搭建zabbix监控以及邮件报警的超级详细教学
2022/07/15 Servers
HttpClient实现表单提交上传文件
2022/08/14 Java/Android