正如问题所暗示的那样,我似乎无法使用所需的选项(AES、ECB模式和PKCS7)正确地获得解密的值。
我正在加密如下:
var ENC_KEY = "bXlrZXk="; //"mykey"
var encrypted = CryptoJS.AES.encrypt("hello", CryptoJS.enc.Base64.parse(ENC_KEY),
{
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
console.log('encrypted: ' + encrypted);但是,当我使用下面的方法解密这个值时,最终输出的是一个空对象:
var decrypted = CryptoJS.AES.decrypt(encrypted, CryptoJS.enc.Base64.parse(ENC_KEY),
{
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
console.log('decrypted: ' + decrypted);我也曾尝试使用:
console.log('encrypted is decrypted to: ' + decrypted.toString(CryptoJS.enc.Utf8);但是没有joy..。
发布于 2014-11-27 14:01:11
我在小提琴里试过这个(为了让它工作,我做了一些模特儿):
//decrypt gives a hex
function hex2a(hexx) {
var hex = hexx.toString();//force conversion
var str = '';
for (var i = 0; i < hex.length; i += 2)
str += String.fromCharCode(parseInt(hex.substr(i, 2), 16));
return str;
}
var key = CryptoJS.enc.Base64.parse("Secret Passphrase");
alert(key);
var encrypted = CryptoJS.AES.encrypt("hello", key,
{
mode: CryptoJS.mode.ECB
});
alert('encrypted: ' + encrypted);
var decrypted = CryptoJS.AES.decrypt(encrypted, key,
{
mode: CryptoJS.mode.ECB
});
alert('decrypted: ' + hex2a(decrypted));http://jsfiddle.net/gttL705r/
发现解密返回了一个巫术,这可能不是字符串.这会导致你的问题吗?因此,使用快速的hex2ascii函数,“hello”返回:)
我还删除了指定的填充,因为据说Pkcs7是文档中的默认内容,我找不到我需要下载的src。
https://stackoverflow.com/questions/27171390
复制相似问题