之前要用到 Mcrypt 进行加解密,在网上搜了一段现成的代码拿来用,使用后发现出现乱码,百寻不得答案,自己不断测试修改,终于发现问题。
网上的代码:
<?
// Encrypt Function
function mc_encrypt($encrypt, $mc_key) {
$iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB), MCRYPT_RAND);
$passcrypt = trim(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $mc_key, trim($encrypt), MCRYPT_MODE_ECB, $iv));
$encode = base64_encode($passcrypt);
return $encode;
}
// Decrypt Function
function mc_decrypt($decrypt, $mc_key) {
$decoded = base64_decode($decrypt);
$iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB), MCRYPT_RAND);
$decrypted = trim(mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $mc_key, trim($decoded), MCRYPT_MODE_ECB, $iv));
return $decrypted;
}
?>
后来参考了下:http://blog.csdn.net/qq271757232/article/details/14119847 以为是 key 长度的问题,将 key 从 8 位增加到 32 位,还是有乱码。
网上关于 Mcrypt 乱码的文章很少,于是将 MCRYPT_RIJNDAEL_256
换成 MCRYPT_DES,以为解决了,但是后台监控到的脚本依然会有乱码。
function mc_encrypt($encrypt, $mc_key) {
$passcrypt = trim(mcrypt_encrypt(MCRYPT_DES, $mc_key, trim($encrypt), MCRYPT_MODE_ECB));
$encode = base64_encode($passcrypt);
return $encode;
}
function mc_decrypt($decrypt, $mc_key) {
$decoded = base64_decode(trim($decrypt));
$decrypted = trim(mcrypt_decrypt(MCRYPT_DES, $mc_key, $decoded, MCRYPT_MODE_ECB));
return $decrypted;
}
突然想到之前看的文章,Mcrypt解密时末尾会出现空白字符:http://php.net/manual/en/function.mcrypt-encrypt.php,所以要进行trim处理
这有个误区,有人把加密后的字符串也进行了trim,trim(mcrypt_encrypt(MCRYPT_DES, $mc_key, trim($encrypt), MCRYPT_MODE_ECB)),而正是这一步,照成了乱码的出现,我用strlen测试了下加密后的字符串$passcrypt的长度,没有trim的长度为384,trim后字符串长度为383。不对 $passcrypt 进行 trim 可以正常解密,末尾没有乱码。
正是由于对 $passcrypt 进行了 trim,两者的长度不一致了,解密出来的数据也不一致了。
因此,只需在最后一步,即解密时进行 trim 操作即可,trim(mcrypt_decrypt(...)),到此,所有问题解决。
测试数据:
$str = {"type":"access_log","ip":"177.71.246.231","agent":"Mozilla\/5.0 (Windows NT 6.1; rv:24.0) Gecko\/20100101 Firefox\/24.0","url":null,"referer":null,"session_id":"7o6u1uju3cp5vupkvs7uf84ga4","created_at":"2013-11-05 10:34:31","ext1":"1383096832703","ext2":"2013-11-05","ext3":"1680x1050","ext4":"2013-11-05","ext5":"BR","ext6":"12qndikf3onbguqfffeg2ghmk3","ext7":0,"ext8":"pt-BR"}
正确的加解密函数应该是:
function mc_encrypt($encrypt, $mc_key) {
$passcrypt = mcrypt_encrypt(MCRYPT_DES, $mc_key, trim($encrypt), MCRYPT_MODE_ECB);
$encode = base64_encode($passcrypt);
return $encode;
}
function mc_decrypt($decrypt, $mc_key) {
$decoded = base64_decode(trim($decrypt));
$decrypted = trim(mcrypt_decrypt(MCRYPT_DES, $mc_key, $decoded, MCRYPT_MODE_ECB));
return $decrypted;
}