需要注意的是,除了 ecb 模式外,所有密码模式都需要在解密时使用与加密时相同的 IV。
您需要将密钥 *和* IV 传递给您的解密函数。在解密例程中初始化新的 IV 将不起作用。
由于“您甚至可以将 [IV] 与密文一起发送而不会丢失安全性”,因此处理此问题的不错方法是在密文前添加 IV。由于 IV 具有固定宽度,因此您可以使用 mcrypt_get_iv_size() 和 substr() 轻松地恢复 IV 和原始密文。
这是一个例子
<?PHP
function my_encrypt($string,$key) {
srand((double) microtime() * 1000000); $key = md5($key); $td = mcrypt_module_open('des', '','cfb', '');
$key = substr($key, 0, mcrypt_enc_get_key_size($td));
$iv_size = mcrypt_enc_get_iv_size($td);
$iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
if (mcrypt_generic_init($td, $key, $iv) != -1) {
$c_t = mcrypt_generic($td, $string);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
$c_t = $iv.$c_t;
return $c_t;
} }
function my_decrypt($string,$key) {
$key = md5($key); $td = mcrypt_module_open('des', '','cfb', '');
$key = substr($key, 0, mcrypt_enc_get_key_size($td));
$iv_size = mcrypt_enc_get_iv_size($td);
$iv = substr($string,0,$iv_size);
$string = substr($string,$iv_size);
if (mcrypt_generic_init($td, $key, $iv) != -1) {
$c_t = mdecrypt_generic($td, $string);
mcrypt_generic_deinit($td);
mcrypt_module_close($td);
return $c_t;
} }
?>