兼容.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);
posted @ 2011-08-31 15:42  蓝色夏威夷  阅读(354)  评论(0编辑  收藏  举报