php专区

 首页 > php专区 > PHP应用 > php类库 > php 3des加密解密类程序代码 - php类库

php 3des加密解密类程序代码 - php类库

分享到:
【字体:
导读:
          php 3des加密解密是一个在数据传输中常用的一个简单的加密方式了,下面我整理了一个php 3des加密解密类程序有需要了解的朋友可进入参考.3DES(或称为Triple DES)是三重数据加密算法(TDEA,Tri...

php 3des加密解密类程序代码

php 3des加密解密是一个在数据传输中常用的一个简单的加密方式了,下面我整理了一个php 3des加密解密类程序有需要了解的朋友可进入参考.

3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称,它相当于是对每个数据块应用三次DES加密算法,由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解,3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法.

php 3des加密解密类程序代码如下:

  1. class Crypt3Des { 
  2. var $key
  3. function Crypt3Des($key){ 
  4. $this->key = $key
  5.  
  6. function encrypt($input){ 
  7. $size = mcrypt_get_block_size(MCRYPT_3DES,'ecb'); 
  8. $input = $this->pkcs5_pad($input$size); 
  9. $key = str_pad($this->key,24,'0'); 
  10. $td = mcrypt_module_open(MCRYPT_3DES, '''ecb'''); 
  11. $iv = @mcrypt_create_iv (mcrypt_enc_get_iv_size($td), MCRYPT_RAND); 
  12. @mcrypt_generic_init($td$key$iv); 
  13. $data = mcrypt_generic($td$input); 
  14. mcrypt_generic_deinit($td); 
  15. mcrypt_module_close($td); 
  16. //$data = base64_encode($this->PaddingPKCS7($data)); 
  17. $data = base64_encode($data); 
  18. return $data
  19.  
  20. function decrypt($encrypted){ 
  21. $encrypted = base64_decode($encrypted); 
  22. $key = str_pad($this->key,24,'0'); 
  23. $td = mcrypt_module_open(MCRYPT_3DES,'','ecb',''); 
  24. $iv = @mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND); 
  25. $ks = mcrypt_enc_get_key_size($td); 
  26. @mcrypt_generic_init($td$key$iv); 
  27. $decrypted = mdecrypt_generic($td$encrypted); 
  28. mcrypt_generic_deinit($td); 
  29. mcrypt_module_close($td); 
  30. $y=$this->pkcs5_unpad($decrypted); 
  31. return $y
  32.  
  33. function pkcs5_pad ($text$blocksize) { 
  34. $pad = $blocksize - (strlen($text) % $blocksize); 
  35. return $text . str_repeat(chr($pad), $pad); 
  36.  
  37. function pkcs5_unpad($text){ 
  38. $pad = ord($text{strlen($text)-1}); 
  39. if ($pad > strlen($text)) { 
  40.    return false; 
  41. if (strspn($textchr($pad), strlen($text) - $pad) != $pad){ 
  42.    return false; 
  43. return substr($text, 0, -1 * $pad); 
  44. //开源代码phpfensi.com 
  45. function PaddingPKCS7($data) { 
  46. $block_size = mcrypt_get_block_size(MCRYPT_3DES, MCRYPT_MODE_CBC); 
  47. $padding_char = $block_size - (strlen($data) % $block_size); 
  48. $data .= str_repeat(chr($padding_char),$padding_char); 
  49. return $data
  50. ?> 

用法:

$crypt = new Crypt3Des('密钥');

$a = '待加密字符串';

$code = $crypt->encrypt($a);//加密

echo $crypt->decrypt($code);//解密

分享到:
php 完美的rss 生成类 - php类库
php 完美的rss 生成类
一个简单的PHP防注入类 - php类库
一个简单的PHP防注入类 PHP防注入注意要过滤的信息基本是get,post,然后对于sql就是我们常用的查询,插入等等sql命令了,下面我给各位整理两个简单的例子,希望这些例子能给你网站带来安全. PHP防注入类代码如下:   例子二,代码如下:
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……