Php mcrypt编码/解码链路问题

Php mcrypt编码/解码链路问题,php,mcrypt,Php,Mcrypt,这是我的编码url参数aKVXt4_P78X64w5ApVAZJ0fSNpV_GGFWxBs0aE_xw24ghq1c5awaappkybzsi0rgjumyplohvp0fe4-jHQnN 当加密类对其进行解码时,结果是±�щПⶳаI§эЁЪ™МkVЃ°(ѓ7m‰e+ц*“V«;Ё@ЧB§Z{ЋèJцццe 我不明白这类问题的原因,它很少发生,但也带来了一些麻烦 要解开/解码链接,我使用这样的类 class Encryption { // config local ENCRIPTION_KEY

这是我的编码url参数aKVXt4_P78X64w5ApVAZJ0fSNpV_GGFWxBs0aE_xw24ghq1c5awaappkybzsi0rgjumyplohvp0fe4-jHQnN

当加密类对其进行解码时,结果是
±�щПⶳаI§эЁЪ™МkVЃ°(ѓ7m‰e+ц*“V«;Ё@ЧB§Z{ЋèJцццe

我不明白这类问题的原因,它很少发生,但也带来了一些麻烦

要解开/解码链接,我使用这样的类

class Encryption {
// config local ENCRIPTION_KEY
var $skey = ENCRIPTION_KEY; 

private function safe_b64encode($string) {
    $data = base64_encode($string);
    $data = str_replace(array('+','/','='),array('-','_',''),$data);
    return $data;
}

private function safe_b64decode($string) {
    $data = str_replace(array('-','_'),array('+','/'),$string);
    $mod4 = strlen($data) % 4;
    if ($mod4) {
        $data .= substr('====', $mod4);
    }
    return base64_decode($data);
}

public  function encode($value){
    if(!$value){return false;}
    $text = $value;
    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_ECB);
    $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
    $crypttext = trim(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $this->skey, trim($text), MCRYPT_MODE_ECB, $iv));
    return trim($this->safe_b64encode($crypttext));
}

public function decode($value){
    if(!$value){return false;}
    $crypttext = $this->safe_b64decode($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, $this->skey, $crypttext, MCRYPT_MODE_ECB, $iv);
    return trim($decrypttext);
}
}

我相信你遇到的问题是,你正在使用一个随机IV加密,然后尝试使用一个完全不同的随机IV解密。拥有一个随机IV很重要,但你需要相同的IV来解密。只要常数密钥被隐藏,IV就不需要是秘密的

当丹尼尔说ECB不使用IV时,它是正确的。它会忽略它,所以最后一段现在是哑巴。但是,你应该考虑从ECB切换到CBC,因为它更安全(仅仅因为它确实使用了IV)。
我编写了一个小类,在CBC模式下使用MCRYPT进行加密/解密(允许任何支持的加密算法,例如BLOWFISH、TWOFISH、RIJNDAEL等)。加密时,它会创建一个随机IV,然后在以十六进制返回整批之前将其前置到加密字符串。然后,当它需要解密同一字符串时,它会转换回bin,确定加密算法的IV大小,从加密字符串中移除IV,并使用它返回解密字符串。如果您认为是这样的话ht帮助,你可以。希望能有帮助。

尝试使用这不是你的问题,但为什么在使用ECB模式时要生成并使用IV?ECB模式不使用IV。它们之间有什么区别?John Conde我不能使用该代码,beacase base64_解码/解码可以断开我的链接