需要注意的是,除了 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;
} }
?>