企业网站搜索优化网络推广,商家推广平台有哪些,vue制作WordPress主题,株洲网站排名优化价格简介
1.aes加密简单来说#xff0c;在密码学中又称Rijndael加密法#xff0c;是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES#xff0c;已经被多方分析且广为全世界所使用。高级加密标准已然成为对称密钥加密中最流行的算法之一。
2.AES的区块长度固定…简介
1.aes加密简单来说在密码学中又称Rijndael加密法是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES已经被多方分析且广为全世界所使用。高级加密标准已然成为对称密钥加密中最流行的算法之一。
2.AES的区块长度固定为128 比特密钥长度则可以是128192或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));