专栏首页王磊的博客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。

  具体的加密算法和模式的区别:点击《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));

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Asp.net中Js、Css文件压缩辅助类

    类名:WebCompressUtility.cs 代码如下: /// <summary> /// Js、Css文件压缩辅助类 /// Stone_W /// 2...

    Java中文社群_老王
  • Java核心(三)并发中的线程同步与锁

    乐观锁、悲观锁、公平锁、自旋锁、偏向锁、轻量级锁、重量级锁、锁膨胀...难理解?不存的!来,话不多说,带你飙车。

    Java中文社群_老王
  • c#字符相似度对比通用类

    本类适用于比较2个字符的相似度,代码如下: using System; using System.Collections.Generic; using Syst...

    Java中文社群_老王
  • javascript中的for in 和 in运算符

    版权声明:本文为吴孔云博客原创文章,转载请注明出处并带上链接,谢谢。 https://blog.csdn.net/wkyseo/articl...

    空空云
  • Nvidia与Scripps合作研究AI在基因组学处理和分析中的作用

    Scripps Research Translational Institute(SRTI)是一家非营利性研究机构,与Nvidia合作开发基于AI的基因组学处理...

    AiTechYun
  • python 编程实例 1

    #题目:有 1、2、3、4 个数字,能组成多少个互不相同且无重复数字的三位数?都是多 

    py3study
  • OPS漫谈之一:通过VLAN配置看OPS系统架构

    OPS(OpenSwitch)是个开源交换机项目,其开源社区(www.openswitch.net)由惠普主导,目前得到了越来越多的关注和认可。本文旨在通过梳理...

    SDNLAB
  • MySQL探秘(八):InnoDB的事务

     事务是数据库最为重要的机制之一,凡是使用过数据库的人,都了解数据库的事务机制,也对ACID四个基本特性如数家珍。但是聊起事务或者ACID的底层实现原理,往往言...

    remcarpediem
  • Python GUI 03----But

    创建三个Button,各自对应回调函数;将第二个Button设置焦点,程序运行是按“Enter”,判断程序的打印结果

    py3study
  • SpringBoot解决Shiro导致依赖注入的bean事务失效问题

    由于shiroFilter在Spring自动装配bean之前实例化 在继承了AuthorizingRealm的类里使用依赖注入的bean及相关联的Bean会被...

    試毅-思伟

扫码关注云+社区

领取腾讯云代金券