首先,请原谅这个问题,这可能是一个简单的问题,但我在理解加密方法时遇到了麻烦。
我使用以下函数来加密/解密:
private function encodemc($value,$skey){
if(!$value){return false;}
$skey = substr($skey, 2, 4);
$text = $value;
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $skey, $text, MCRYPT_MODE_ECB, $iv);
return trim($this->safe_encode($crypttext)); // safe_encode adds another encoding using `base64_encode`
}
private function decodemc($value,$skey){
if(!$value){return false;}
$skey = substr($skey, 2, 4);
$crypttext = $this->safe_decode($value);
$iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
$decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $skey, $crypttext, MCRYPT_MODE_ECB, $iv);
return trim($decrypttext);
}$key看起来像这样:570c45546dwq45gjk191。
问题是一些文本没有得到正确的解密/加密,并且它在html页面中显示,就好像它使用了错误的文本编码。
奇怪的是,在10个项目中,只有2到3个项目是乱码,这取决于钥匙。此外,有时只有一部分字符串是乱码。
我发现造成乱码的原因是一些随机的字母。例如,当使用上面的键时,字母S破坏了代码,文本变得乱码。
因此,我对键应用了substr($skey, 2, 4);,看看是否有什么变化。原来,如果我改变密钥,破解代码的字符是不同的。
但是,即使使用长度为== 1的密钥,问题仍然存在。
你知道问题出在哪里吗?
编辑:
下面是代码的其余部分。
private function safe_encode($string) {
$data = base64_encode($string);
$data = str_replace(array('+','/','='),array('-','_',''),$data);
return $data;
}
private function safe_decode($string) {
$data = str_replace(array('-','_'),array('+','/'),$string);
$mod4 = strlen($data) % 4;
if ($mod4) {
$data .= substr('====', $mod4);
}
return stripslashes(base64_decode($data));
}发布于 2013-01-07 19:20:54
这似乎是一个非常奇怪的问题。
我没有给你一个明确的答案,但这里有几个你可以尝试的事情。
safe_encode和safe_decode代码。如果问题消失,则这些函数会添加/删除重要的内容。一次完成以上所有操作很重要,因为可能会有多个问题。如果上述步骤解决了问题,则一次重新引入一个步骤,以确定导致问题的原因。
https://stackoverflow.com/questions/14194642
复制相似问题