校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PHP對稱加密算法(DES/AES)類的實現代碼

PHP對稱加密算法(DES/AES)類的實現代碼

熱門標簽:周口網絡回撥外呼系統 商丘外呼系統好處 網絡電話400申請 全國各省地圖標注點 400電話申請辦理 百度地圖標注類型是酒店 外呼系統人工客服 隨州銷售電銷機器人公司 福建高頻外呼防封系統哪家好

對稱密鑰加密機制即對稱密碼體系,也稱為單鑰密碼體系和傳統密碼體系。對稱密碼體系通常分為兩大類,一類是分組密碼(如DES、AES算法),另一類是序列密碼(如RC4算法)。

AES 是一個新的可以用于保護電子數據的加密算法。明確地說,AES 是一個迭代的、對稱密鑰分組的密碼,它可以使用128、192 和 256 位密鑰,并且用 128 位(16字節)分組加密和解密數據。與公共密鑰密碼使用密鑰對不同,對稱密鑰密碼使用相同的密鑰加密和解密數據。通過分組密碼返回的加密數據 的位數與輸入數據相同。迭代加密使用一個循環結構,在該循環中重復置換(permutations )和替換(substitutions)輸入數據。Figure 1 顯示了 AES 用192位密鑰對一個16位字節數據塊進行加密和解密的情形。

那DES是什么呢?DES全稱為Data Encryption Standard,即數據加密標準,是一種使用密鑰加密的塊算法,1977年被美國聯邦政府的國家標準局確定為聯邦資料處理標準(FIPS),并授權在非密級政府通信中使用,隨后該算法在國際上廣泛流傳開來。需要注意的是,在某些文獻中,作為算法的DES稱為數據加密算法(Data Encryption Algorithm,DSA),已與作為標準的DES區分開來。

DES設計中使用了分組密碼設計的兩個原則:混淆(confusion)和擴散(diffusion),其目的是抗擊敵手對密碼系統的統計分析。混淆是使密文的統計特性與密鑰的取值之間的關系盡可能復雜化,以使密鑰和明文以及密文之間的依賴性對密碼分析者來說是無法利用的。擴散的作用就是將每一位明文的影響盡可能迅速地作用到較多的輸出密文位中,以便在大量的密文中消除明文的統計結構,并且使每一位密鑰的影響盡可能迅速地擴展到較多的密文位中,以防對密鑰進行逐段破譯。

/** 
 * 常用對稱加密算法類 
 * 支持密鑰:64/128/256 bit(字節長度8/16/32) 
 * 支持算法:DES/AES(根據密鑰長度自動匹配使用:DES:64bit AES:128/256bit) 
 * 支持模式:CBC/ECB/OFB/CFB 
 * 密文編碼:base64字符串/十六進制字符串/二進制字符串流 
 * 填充方式: PKCS5Padding(DES) 
 * 
 * @author: linvo 
 * @version: 1.0.0 
 * @date: 2013/1/10 
 */  
class Xcrypt{  
  
  private $mcrypt;  
  private $key;  
  private $mode;  
  private $iv;  
  private $blocksize;  
  
  /** 
   * 構造函數 
   * 
   * @param string 密鑰 
   * @param string 模式 
   * @param string 向量("off":不使用 / "auto":自動 / 其他:指定值,長度同密鑰) 
   */  
  public function __construct($key, $mode = 'cbc', $iv = "off"){  
    switch (strlen($key)){  
    case 8:  
      $this->mcrypt = MCRYPT_DES;  
      break;  
    case 16:  
      $this->mcrypt = MCRYPT_RIJNDAEL_128;  
      break;  
    case 32:  
      $this->mcrypt = MCRYPT_RIJNDAEL_256;  
      break;  
    default:  
      die("Key size must be 8/16/32");  
    }  
  
    $this->key = $key;  
  
    switch (strtolower($mode)){  
    case 'ofb':  
      $this->mode = MCRYPT_MODE_OFB;  
      if ($iv == 'off') die('OFB must give a IV'); //OFB必須有向量  
      break;  
    case 'cfb':  
      $this->mode = MCRYPT_MODE_CFB;  
      if ($iv == 'off') die('CFB must give a IV'); //CFB必須有向量  
      break;  
    case 'ecb':  
      $this->mode = MCRYPT_MODE_ECB;  
      $iv = 'off'; //ECB不需要向量  
      break;  
    case 'cbc':  
    default:  
      $this->mode = MCRYPT_MODE_CBC;  
    }  
  
    switch (strtolower($iv)){  
    case "off":  
      $this->iv = null;  
      break;  
    case "auto":  
      $source = PHP_OS=='WINNT' ? MCRYPT_RAND : MCRYPT_DEV_RANDOM;  
      $this->iv = mcrypt_create_iv(mcrypt_get_block_size($this->mcrypt, $this->mode), $source);  
      break;  
    default:  
      $this->iv = $iv;  
    }  
  
  }  
  
  /** 
   * 獲取向量值 
   * @param string 向量值編碼(base64/hex/bin) 
   * @return string 向量值 
   */  
  public function getIV($code = 'base64'){  
    switch ($code){  
    case 'base64':  
      $ret = base64_encode($this->iv);  
      break;  
    case 'hex':  
      $ret = bin2hex($this->iv);  
      break;  
    case 'bin':  
    default:  
      $ret = $this->iv;  
    }  
    return $ret;  
  }  
  
  /** 
   * 加密 
   * @param string 明文 
   * @param string 密文編碼(base64/hex/bin) 
   * @return string 密文 
   */  
  public function encrypt($str, $code = 'base64'){  
    if ($this->mcrypt == MCRYPT_DES) $str = $this->_pkcs5Pad($str);  
  
    if (isset($this->iv)) {  
      $result = mcrypt_encrypt($this->mcrypt, $this->key, $str, $this->mode, $this->iv);   
    } else {  
      @$result = mcrypt_encrypt($this->mcrypt, $this->key, $str, $this->mode);   
    }  
  
    switch ($code){  
    case 'base64':  
      $ret = base64_encode($result);  
      break;  
    case 'hex':  
      $ret = bin2hex($result);  
      break;  
    case 'bin':  
    default:  
      $ret = $result;  
    }  
  
    return $ret;  
  
  }  
  
  /** 
   * 解密  
   * @param string 密文 
   * @param string 密文編碼(base64/hex/bin) 
   * @return string 明文 
   */  
  public function decrypt($str, $code = "base64"){    
    $ret = false;  
  
    switch ($code){  
    case 'base64':  
      $str = base64_decode($str);  
      break;  
    case 'hex':  
      $str = $this->_hex2bin($str);  
      break;  
    case 'bin':  
    default:  
    }  
  
    if ($str !== false){  
      if (isset($this->iv)) {  
        $ret = mcrypt_decrypt($this->mcrypt, $this->key, $str, $this->mode, $this->iv);   
      } else {  
        @$ret = mcrypt_decrypt($this->mcrypt, $this->key, $str, $this->mode);   
      }  
      if ($this->mcrypt == MCRYPT_DES) $ret = $this->_pkcs5Unpad($ret);  
    }  
  
    return $ret;   
  }   
  
  private function _pkcs5Pad($text){  
    $this->blocksize = mcrypt_get_block_size($this->mcrypt, $this->mode);   
    $pad = $this->blocksize - (strlen($text) % $this->blocksize);  
    return $text . str_repeat(chr($pad), $pad);  
  }  
  
  private function _pkcs5Unpad($text){  
    $pad = ord($text{strlen($text) - 1});  
    if ($pad > strlen($text)) return false;  
    if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false;  
    $ret = substr($text, 0, -1 * $pad);  
    return $ret;  
  }  
  
  private function _hex2bin($hex = false){  
    $ret = $hex !== false  preg_match('/^[0-9a-fA-F]+$/i', $hex) ? pack("H*", $hex) : false;    
    return $ret;  
  }  
  
}  

使用實例

?php  
header('Content-Type:text/html;Charset=utf-8;');  
  
include "xcrypt.php";  
  
echo 'pre>';  
//////////////////////////////////////  
$a = isset($_GET['a']) ? $_GET['a'] : '測試123';  
  
//密鑰  
$key = '12345678123456781234567812345678'; //256 bit  
$key = '1234567812345678'; //128 bit  
$key = '12345678'; //64 bit  
  
//設置模式和IV  
$m = new Xcrypt($key, 'cbc', 'auto');  
  
//獲取向量值  
echo '向量:';  
var_dump($m->getIV());  
  
//加密  
$b = $m->encrypt($a, 'base64');  
//解密  
$c = $m->decrypt($b, 'base64');  
  
echo '加密后:';  
var_dump($b);  
echo '解密后:';  
var_dump($c);  
  
/////////////////////////////////////////  
echo '/pre>'; 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP 7.1中AES加解密方法mcrypt_module_open()的替換方案
  • PHP實現的簡單AES加密解密算法實例
  • JS實現AES加密并與PHP互通的方法分析
  • PHP的AES加密算法完整實例
  • PHP aes (ecb)解密后亂碼問題
  • PHP實現AES256加密算法實例
  • php中AES加密解密的例子小結
  • 如何在PHP中使用AES加密算法加密數據

標簽:六安 海南 佛山 定西 樂山 迪慶 十堰 南寧

巨人網絡通訊聲明:本文標題《PHP對稱加密算法(DES/AES)類的實現代碼》,本文關鍵詞  PHP,對稱,加密,算法,DES,AES,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP對稱加密算法(DES/AES)類的實現代碼》相關的同類信息!
  • 本頁收集關于PHP對稱加密算法(DES/AES)類的實現代碼的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    精品一区中文字幕| 综合av第一页| 91精品国产高清一区二区三区蜜臀| 色婷婷狠狠综合| 日本韩国一区二区| 欧洲一区二区三区在线| 欧美三级电影在线观看| 91精品在线麻豆| 日韩午夜精品视频| 久久综合视频网| 国产欧美一区二区精品性| 国产精品三级在线观看| 亚洲视频你懂的| 一卡二卡欧美日韩| 免费观看成人av| 国产激情偷乱视频一区二区三区| 国产福利一区二区| 91丝袜呻吟高潮美腿白嫩在线观看| 色哦色哦哦色天天综合| 欧美久久一二三四区| 精品久久久久久久一区二区蜜臀| 国产亚洲精品资源在线26u| 国产精品日韩成人| 亚洲福利一二三区| 精品亚洲国产成人av制服丝袜 | 亚洲色欲色欲www在线观看| 亚洲一区日韩精品中文字幕| 日本v片在线高清不卡在线观看| 韩国女主播一区二区三区| 成人免费看的视频| 欧美日韩成人在线| 国产偷国产偷亚洲高清人白洁| 亚洲欧美偷拍三级| 美女视频网站久久| 久久午夜国产精品| 日韩专区一卡二卡| 国产一区视频在线看| 99精品欧美一区二区三区小说| 欧美日韩精品一区二区三区蜜桃 | www激情久久| 亚洲免费在线播放| 久久99在线观看| 91精品福利在线| 日本一区二区三区久久久久久久久不 | 播五月开心婷婷综合| 欧美巨大另类极品videosbest| 国产欧美一区在线| 麻豆91免费看| 欧美三日本三级三级在线播放| 国产日韩高清在线| 另类小说欧美激情| 欧美日韩在线免费视频| 中文字幕在线一区| 国产成人在线免费| 日韩欧美一区二区三区在线| 亚洲精品视频自拍| 成人av动漫在线| 国产日韩欧美精品一区| 精品无人区卡一卡二卡三乱码免费卡| 在线观看亚洲成人| 18成人在线视频| aaa欧美大片| 成人免费视频在线观看| 国产福利一区二区三区在线视频| 日韩免费观看高清完整版在线观看| 一区二区三区在线影院| 91蜜桃传媒精品久久久一区二区| 国产精品色在线观看| 国产mv日韩mv欧美| 久久精品在线免费观看| 国产精品一区二区三区99| 久久午夜免费电影| 国产麻豆一精品一av一免费| 亚洲精品在线观看网站| 国产一区二区三区电影在线观看 | 欧美亚洲日本国产| 亚洲福利视频一区| 欧美日韩aaaaa| 亚洲午夜在线观看视频在线| 在线免费av一区| 午夜激情综合网| 欧美一卡2卡3卡4卡| 老司机午夜精品99久久| 久久―日本道色综合久久| 国产精品一级黄| 中文字幕亚洲一区二区va在线| 不卡在线视频中文字幕| 亚洲综合免费观看高清完整版| 在线日韩一区二区| 亚洲成a人在线观看| 日韩一区二区精品| 国内精品免费**视频| 中文子幕无线码一区tr| 色婷婷国产精品综合在线观看| 亚洲成av人片一区二区| 精品久久久久久久人人人人传媒| 国产精品伊人色| 一区二区三区在线视频免费观看| 欧美午夜不卡在线观看免费| 日本视频免费一区| 中日韩av电影| 欧美精品视频www在线观看| 国产真实精品久久二三区| 中文字幕一区二区三区精华液| 欧美三级电影在线观看| 国产激情偷乱视频一区二区三区| 亚洲日本va在线观看| 日韩精品一区二区三区swag| 成人激情av网| 日韩黄色免费网站| 国产精品色呦呦| 日韩欧美不卡一区| aaa亚洲精品一二三区| 日韩制服丝袜av| 国产精品免费aⅴ片在线观看| 欧美日韩一区二区不卡| 夫妻av一区二区| 日本va欧美va欧美va精品| 中文字幕亚洲电影| 欧美精品一区二区久久婷婷 | 亚洲国产成人av网| 中文字幕av在线一区二区三区| 91精品国产综合久久福利软件 | 中文字幕成人在线观看| 日韩一区二区免费高清| 欧美在线观看一区二区| 成人看片黄a免费看在线| 免费观看在线综合| 亚洲自拍偷拍网站| 中文字幕在线一区二区三区| 精品日韩99亚洲| 欧美日韩国产综合一区二区三区| av中文字幕亚洲| 国产大片一区二区| 国产在线一区观看| 麻豆一区二区三| 视频在线观看国产精品| 亚洲成人av电影在线| 亚洲最大成人综合| 亚洲精品国产高清久久伦理二区| 国产精品乱人伦中文| 久久久高清一区二区三区| 日韩精品在线一区二区| 538prom精品视频线放| 欧美男男青年gay1069videost| 91麻豆精品在线观看| 一本到三区不卡视频| 91色视频在线| 日本韩国欧美一区| 欧美三电影在线| 欧美高清www午色夜在线视频| 欧美日韩dvd在线观看| 欧美精品v国产精品v日韩精品 | 久久精品男人天堂av| 2022国产精品视频| 欧美精品一区二区三区久久久| 精品国产区一区| 久久精品这里都是精品| 国产精品麻豆久久久| 亚洲精品综合在线| 欧美日韩一区不卡| 欧美嫩在线观看| 久久久亚洲欧洲日产国码αv| 日韩美女视频在线| 欧美大片在线观看| 国产三级一区二区| 国产精品久久久久久久浪潮网站 | 毛片av中文字幕一区二区| 免费成人深夜小野草| 国产一区不卡视频| 成人高清视频在线| 99久久亚洲一区二区三区青草| 91毛片在线观看| 337p亚洲精品色噜噜噜| 26uuu欧美| 亚洲精品你懂的| 日韩精品每日更新| 国产a视频精品免费观看| 99r国产精品| 在线综合亚洲欧美在线视频 | 国产乱国产乱300精品| 不卡视频一二三四| 欧美日本在线一区| 国产日韩精品一区二区浪潮av| 亚洲精品美腿丝袜| 韩国一区二区三区| 91美女片黄在线| 欧美精品一区二区三区四区| 亚洲免费资源在线播放| 久久99精品久久久久婷婷| 色综合婷婷久久| 久久久蜜桃精品| 亚洲图片有声小说| 成人高清免费在线播放| 欧美日韩三级视频| 中文字幕人成不卡一区| 久久成人18免费观看| 色网综合在线观看| 国产午夜亚洲精品不卡| 偷窥少妇高潮呻吟av久久免费|