nodejs与javascript中的aes加密

 
// var CryptoJS = require("crypto-js");
// var key = CryptoJS.enc.Utf8.parse("8NONwyJtHesysWpM");
var crypto = require('crypto');
var key = new Buffer('7y05R9qwKaIKgIHh4vAw19X1zuknR21Y', 'binary');
var iv = "";
var cryto_aes = module.exports = {};
 
//加密
cryto_aes.Encrypt = function(data){
 
  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('');
}

 

//解密
cryto_aes.Decrypt = function(data){
 
  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('');
 
}
 
 
参考:http://www.cnblogs.com/vipstone/p/5514886.html
参照上述方法时注意 iv 和 key的设置  可能会报Invalid IV length 错  解决方法 就是 设置成我粘贴的代码中的格式。
 

 

posted @ 2017-08-08 17:16  我叫阿良❤善良的良  阅读(598)  评论(0编辑  收藏  举报