• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    php DES加密算法实例分析

    本文实例讲述了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,"\0");    
       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 (empty($key) || empty($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);
      }
    }
    ?>
    
    

    PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:

    在线DES加密/解密工具
    http://tools.jb51.net/password/des_encode

    MD5在线加密工具:
    http://tools.jb51.net/password/CreateMD5Password

    在线散列/哈希算法加密工具:
    http://tools.jb51.net/password/hash_encrypt

    在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
    http://tools.jb51.net/password/hash_md5_sha

    在线sha1/sha224/sha256/sha384/sha512加密工具:
    http://tools.jb51.net/password/sha_encode

    更多关于PHP相关内容感兴趣的读者可查看本站专题:《php加密方法总结》、《PHP编码与转码操作技巧汇总》、《PHP数学运算技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》

    希望本文所述对大家PHP程序设计有所帮助。

    您可能感兴趣的文章:
    • PHP实现基于3DES算法加密解密字符串示例
    • PHP对称加密算法(DES/AES)类的实现代码
    • php实现和c#一致的DES加密解密实例
    • PHP实现的DES加密解密封装类完整实例
    • PHP简单实现DES加密解密的方法
    • PHP中加密解密函数与DES加密解密实例
    • 兼容PHP和Java的des加密解密代码分享
    • 如何通过PHP实现Des加密算法代码实例
    上一篇:php实现QQ小程序发送模板消息功能
    下一篇:PHP实现批量修改文件名的方法示例
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    php DES加密算法实例分析 php,DES,加密,算法,实例分析,