用PHP mcrypt加密后用Javascript CryptoJS解密AES

时间:2014-10-29 06:10:09

标签: javascript encryption aes mcrypt cryptojs

使用mcrypt在PHP中加密

<?php
$string = 'Secret Message';
$key = 'd4b494e4502a62edd695a903a94c2701';
$iv = '02f30dffbb0d084755f438f7d8be4a7d';

$encrypted = base64_encode(
    mcrypt_encrypt(
        MCRYPT_RIJNDAEL_256,
        $key,
        $string,
        MCRYPT_MODE_CBC,
        $iv
    )
);
//$encrypted results in 'nYoFAiyDARVSI09lH/IPdim5TvE51izVjk6sc2AK9Rg='
?>

使用CryptoJS解密Javascript

<script>
var encrypted = 'nYoFAiyDARVSI09lH/IPdim5TvE51izVjk6sc2AK9Rg=';
var key = CryptoJS.enc.Hex.parse('d4b494e4502a62edd695a903a94c2701');
var iv = CryptoJS.enc.Hex.parse('02f30dffbb0d084755f438f7d8be4a7d');

var decrypted = CryptoJS.AES.decrypt(encrypted,key,{iv:iv,mode:CryptoJS.mode.CBC,padding:CryptoJS.pad.Pkcs7});

console.log(decrypted.toString(CryptoJS.enc.Utf8)); //prints an empty string
</script>

我无法弄清楚如何让Javascript端吐出原始文本。

1 个答案:

答案 0 :(得分:6)

<强>解决

注意:我发现&#34; MCRYPT_RIJNDAEL_256&#34;在PHP中,mcrypt不包含在AES中。它使用Rijndael方法,BUT具有256位块大小(不包括在AES中)。因此,CryptoJS不能处理Rijndael的256位块大小。谢谢,GregS

尽管如此,我找到了一个实现,它成功解密了我从上面运行我的PHP mcrypt函数获得的密文,使用MCRYPT_RIJNDAEL_256(Rijndael,256位块大小,256位密钥/ 32-字节键)。

这是: https://code.google.com/p/js-mcrypt/

<script>
var encrypted = 'nYoFAiyDARVSI09lH/IPdim5TvE51izVjk6sc2AK9Rg=';
var key = 'd4b494e4502a62edd695a903a94c2701';
var iv = '02f30dffbb0d084755f438f7d8be4a7d';
var decrypted = mcrypt.Decrypt(atob(encrypted), iv, key, 'rijndael-256', 'cbc');
</script>

我希望这可以帮助别人,因为我花了一个星期的业余时间试图解决这个问题并且几乎放弃了。