微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

详解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的使用

rush:js;"> 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',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,iv) {
    if (!data) {
    return "";
    }
    iv = iv || "";
    var clearEncoding = 'utf8';
    var cipherEncoding = 'base64';
    var cipherChunks = [];
    var decipher = crypto.createDecipheriv('aes-256-ecb',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地址:

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

//加密
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,padding: CryptoJS.pad.Pkcs7
});
console.log("value: "+decrypt.toString(CryptoJS.enc.Utf8));

原文作者:西安.王磊 原文出处:

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

原文地址:https://www.jb51.cc/nodejs/48557.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐