php Mcrypt对数据加密和解密方法
1,对数据加密
<?php $key = md5('I need a job'); //密钥 $data = "fuck! find a job continue!";//要加密的数据 $m = mcrypt_module_open('rijndael-256', '', 'cbc', '');//打开加密算子 $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($m),MCRYPT_DEV_RANDOM);//创建初始化向量 mcrypt_generic_init($m, $key, $iv);//加密初始化,创建Mcrypt运行加密所需要的缓存区 $data = mcrypt_generic($m, $data);//加密数据 mcrypt_generic_deinit($m); //关闭缓存 mcrypt_module_close($m);//关闭模块 $_SESSION['data'] = base64_encode($data);//使用base64_encode()函数处理数据以使其能够安全地存储在普通文件中 $_SESSION['iv'] = base64_encode($iv); echo "<p>数据已经存储完毕,值为:".base64_encode($data)."</p>"; ?>
2,数据解密
<?php if(isset($_SESSION['data']) && isset($_SESSION['iv'])){ $m = mcrypt_module_open('rijndael-256', '', 'cbc', '');//打开加密模块 $key = md5('I need a job');//密钥 $iv = base64_decode($_SESSION['iv']);//初始化向量 解密密钥所用的初始化向量必须与加密相同 mcrypt_generic_init($m, $key, $iv);//加密初始化 $data =mdecrypt_generic($m, base64_decode($_SESSION['data']));//解密 mcrypt_generic_deinit($m); mcrypt_module_close($m); echo '<p>会话被读取为:'.trim($data).'</p>'; //输出时要用trim函数去掉解密过程中向数据末尾添加的空白字符 }else{ echo '没有任何会话可读取。'; } ?>