3

我正在寻找AES256 CBC解密客户端,

在 nodeJS 我使用这个函数来加密:

exports.encrypt = function(txt, cryptkey){
  var cipher = crypto.createCipher('aes-256-cbc',cryptkey);
  var crypted = cipher.update(txt,'utf8','hex');
  crypted += cipher.final('hex');

  console.log(crypted);
  return crypted;

};

但我似乎无法在任何客户端库(JSAES.js、SJCL.js、pidcrypt)中使用它

我的猜测是它与base64 / hex编码解码有关,任何指针?

4

1 回答 1

8

请看一下CryptoJS项目:

下面是一个 AES256 CBC 加密/解密的例子:

包括:

<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/rollups/aes.js"></script>
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/mode-cfb-min.js"></script>

JS:

var passPhrase = "Secret Phassphrase";

var encrypted = CryptoJS.AES.encrypt("Message", passPhrase, { mode: CryptoJS.mode.CFB });
var decrypted = CryptoJS.AES.decrypt(encrypted, passPhrase, { mode: CryptoJS.mode.CFB });

console.log('encrypted', encrypted);
console.log('decrypted', decrypted.toString(CryptoJS.enc.Utf8));

在jsFiddle查看演示

于 2013-02-24T18:33:18.797 回答