0

首先,请原谅这个问题,这可能是一个简单的问题,但我无法理解加密方法..

我正在使用以下函数来加密/解密:

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 文本。

问题是某些文本没有得到正确的解密/加密,并且它显示在 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));
}
4

1 回答 1

0

这似乎是一个非常奇怪的问题。

我没有给你一个明确的答案,但这里有几件事你可以尝试。

  1. 加密/解密而不去数据库。如果问题消失,则说明数据库处理通过加密功能输出的字符时存在问题。
  2. 在加密之前修剪值。如果问题消失,则加密后的修剪是错误的
  3. 删除safe_encodesafe_decode代码。如果问题消失了,那么这些功能正在添加/删除重要的东西。

一次完成以上所有操作很重要,因为可能存在多个问题。如果上述步骤消除了问题,则一次重新引入一个,以确定导致问题的原因。

于 2013-01-07T11:20:54.023 回答