兼容.NET的基于DES的PHP加密解密函数
最近由于业务需要一个兼容.NET的加密解密的PHP函数。发现基于mcrypt扩展的des加解密比通过php的原创算法实现在性能方面要提高许多,而且这是一种标准的数据加密方式,应该可以在PHP平台和.NET平台有良好的兼容性。如果服务器上安装了mcrypt扩展,则尽量使用。以下是代码:
/**
* 加解密字符
*
* @param string $string 需要加/解密的串.
* @param string $operation 加/解密模式. DECODE|ENCODE
* @return array
*/
function encrypt($crypt,$mode='DECODE'){
$key = 'coderbol';//任意8位字符串
$iv = mcrypt_create_iv(mcrypt_get_iv_size(MCRYPT_DES,MCRYPT_MODE_ECB),MCRYPT_RAND);
if( 'ENCODE' == $mode ){
$passcrypt = mcrypt_encrypt(MCRYPT_DES ,$key, $crypt, MCRYPT_MODE_ECB, $iv);
$str = str_replace( array('=','/','+'),array('','-','_'), base64_encode($passcrypt) );
}else{
$decoded = base64_decode( str_replace(array('-','_'), array('/','+'), $crypt ) );
$str = mcrypt_decrypt(MCRYPT_DES ,$key, $decoded, MCRYPT_MODE_ECB, $iv);
}
return $str;
}
$str = '蓝色夏威夷的博客';
echo $enstr = encrypt($str,'ENCODE');
echo encrypt($enstr);