nodejs与javascript中的aes加密

前端开发 作者: 2024-08-21 05:40:01
简介 1.aes加密简单来说,在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。高级加密标准已然成为对称密钥加

简介

应用

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 = if (!data) {
        return "";
    }
    iv = iv || ""var decipher = crypto.createDecipheriv('aes-256-ecb');
    cipherChunks.push(decipher.update(data,cipherEncoding,clearEncoding));
    cipherChunks.push(decipher.final(clearEncoding));
    );
}
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,padding: CryptoJS.pad.Pkcs7
});
console.log("value: "+decrypt.toString(CryptoJS.enc.Utf8));
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_65926.html