關於PHP的MCRYPT的解密問題
最近想找一個PHP的密匙可逆加密函數
幾經周折找到了MCRYPT。並在網上找到了一個DEMO
// Designate string to be encrypted
$string = "song";
// Encryption/decryption key
$key = "memeda";
// Encryption Algorithm
$cipher_alg = MCRYPT_RIJNDAEL_128;
// Create the initialization vector for added security.
$iv = mcrypt_create_iv(mcrypt_get_iv_size($cipher_alg, MCRYPT_MODE_ECB), MCRYPT_RAND);
// Output original string
print "Original string: $string ";
// Encrypt $string
$encrypted_string = mcrypt_encrypt($cipher_alg, $key, $string, MCRYPT_MODE_CBC, $iv);
// Convert to hexadecimal and output to browser
print "Encrypted string: ".bin2hex($encrypted_string)."
";
$decrypted_string = mcrypt_decrypt($cipher_alg, $key, $encrypted_string, MCRYPT_MODE_CBC, $iv);
print "Decrypted string: $decrypted_string";
?>
原程式當然可以直接加解密
但是把轉換後的16進位的字串還原成2進位的密文去解密的時候卻發現不能解密了
經過對比發現還原成2進位後的密文和直接加密完的密文是一樣的,為什麼不能解密就很困惑了 希望有人能幫我解答下哈
------解決方案--------------------
$iv 的值改變了
------解決方案--------------------
是的,這是公開祕密金鑰加密演算法
有兩個密鑰
一個是公開金鑰,即 iv 內建於你提供的加解密程式中
一個是私密金鑰,提供給使用者