加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php DES加密算法例子分析

发布时间:2022-06-26 10:35:09 所属栏目:PHP教程 来源:互联网
导读:这篇文章主要介绍了php DES加密算法,结合实例形式分析了yii框架的DES加密算法类定义,以及兼容C#和java的3DES加密算法实现技巧,需要的朋友可以参考下。 本文实例讲述了php DES加密算法,分享给大家供大家参考,具体如下: yii框架的DES代码: ?php /** *@se
  这篇文章主要介绍了php DES加密算法,结合实例形式分析了yii框架的DES加密算法类定义,以及兼容C#和java的3DES加密算法实现技巧,需要的朋友可以参考下。
 
  本文实例讲述了php DES加密算法,分享给大家供大家参考,具体如下:
 
  yii框架的DES代码:
 
  <?php
  /**
   *@see Yii CSecurityManager;
   */
  class Des{
   public static function encrypt($data,$key){
     $module=mcrypt_module_open('des','', MCRYPT_MODE_CBC,'');
     $key=substr(md5($key),0,mcrypt_enc_get_key_size($module));
     srand();
     $iv=mcrypt_create_iv(mcrypt_enc_get_iv_size($module), MCRYPT_RAND);
     mcrypt_generic_init($module,$key,$iv);
     $encrypted=$iv.mcrypt_generic($module,$data);
     mcrypt_generic_deinit($module);
     mcrypt_module_close($module);
     return md5($data).'_'.base64_encode($encrypted);
   }
   public static function decrypt($data,$key){   
     $_data = explode('_',$data,2);
     if(count($_data)<2){
      return false;
     }
     $data = base64_decode($_data[1]);    
     $module=mcrypt_module_open('des','', MCRYPT_MODE_CBC,'');
     $key=substr(md5($key),0,mcrypt_enc_get_key_size($module));
     $ivSize=mcrypt_enc_get_iv_size($module);
     $iv=substr($data,0,$ivSize);
     mcrypt_generic_init($module,$key,$iv);
     $decrypted=mdecrypt_generic($module,substr($data,$ivSize,strlen($data)));
     mcrypt_generic_deinit($module);
     mcrypt_module_close($module);
     $decrypted = rtrim($decrypted,"");     
     if($_data[0]!=md5($decrypted)){
      return false;
     }
     return $decrypted;
   }
  }
  在网上看到了一篇文章,讲到:
 
  由于PHP使用mcrypt扩展进行3DES加密,填充模式是跟JAVA以及.NET是不一样的,JAVA和.NET填充模式使用的是PKCS7。
 
  所以PHP端必须自定义一个函数对加密字符串进行PKCS7模式补位填充。
 
  另外一点就是双方的KEY注意进行base64编码,最后PHP端经过3DES加密后得到的结果也需要进行base64编码。
 
  以上几点都做好之后,加密结果就一致了。
 
  下面是兼容C#和java的3DES加密的算法
 
  <?php
  class STD3Des
  {
    private $key = "";
    private $iv = "";
    /**
    * 构造,传递二个已经进行base64_encode的KEY与IV
    *
    * @param string $key
    * @param string $iv
    */
    function __construct ($key, $iv)
    {
      if (emptyempty($key) || emptyempty($iv)) {
        echo 'key and iv is not valid';
        exit();
      }
      $this->key = $key;
      $this->iv = $iv;
    }
    /**
    *加密
    * @param <type> $value
    * @return <type>
    */
    public function encrypt ($value)
    {
      $td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
      $iv = base64_decode($this->iv);
      $value = $this->PaddingPKCS7($value);
      $key = base64_decode($this->key);
      mcrypt_generic_init($td, $key, $iv);
      $ret = base64_encode(mcrypt_generic($td, $value));
      mcrypt_generic_deinit($td);
      mcrypt_module_close($td);
      return $ret;
    }
    /**
    *解密
    * @param <type> $value
    * @return <type>
    */
    public function decrypt ($value)
    {
      $td = mcrypt_module_open(MCRYPT_3DES, '', MCRYPT_MODE_CBC, '');
      $iv = base64_decode($this->iv);
      $key = base64_decode($this->key);
      mcrypt_generic_init($td, $key, $iv);
      $ret = trim(mdecrypt_generic($td, base64_decode($value)));
      $ret = $this->UnPaddingPKCS7($ret);
      mcrypt_generic_deinit($td);
      mcrypt_module_close($td);
      return $ret;
    }
    private function PaddingPKCS7 ($data)
    {
      $block_size = mcrypt_get_block_size('tripledes', 'cbc');
      $padding_char = $block_size - (strlen($data) % $block_size);
      $data .= str_repeat(chr($padding_char), $padding_char);
      return $data;
    }
    private function UnPaddingPKCS7($text)
    {
      $pad = ord($text{strlen($text) - 1});
      if ($pad > strlen($text)) {
        return false;
      }
      if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) {
        return false;
      }
      return substr($text, 0, - 1 * $pad);
    }
  }
  ?>。
 

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读