欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁(yè) > 知識(shí)庫(kù) > PHP的RSA加密解密方法以及開(kāi)發(fā)接口使用

PHP的RSA加密解密方法以及開(kāi)發(fā)接口使用

熱門(mén)標(biāo)簽:專業(yè)電話機(jī)器人批發(fā)商 400電話申請(qǐng)方法收費(fèi) 南寧高頻外呼回?fù)芟到y(tǒng)哪家好 江蘇外呼電銷機(jī)器人報(bào)價(jià) 深圳外呼系統(tǒng)收費(fèi) 電話機(jī)器人危險(xiǎn)嗎 400電話辦理福州市 長(zhǎng)沙crm外呼系統(tǒng)業(yè)務(wù) 離石地圖標(biāo)注

網(wǎng)絡(luò)安全問(wèn)題很重要,尤其是保證數(shù)據(jù)安全,遇到很多在寫(xiě)接口的程序員直接都是明文數(shù)據(jù)傳輸,在我看來(lái)這是很不專業(yè)的。本人提倡經(jīng)過(guò)接口的數(shù)據(jù)都要進(jìn)行加密解密之后進(jìn)行使用。

這篇文章主要介紹使用PHP開(kāi)發(fā)接口,數(shù)據(jù)實(shí)現(xiàn)RSA加密解密后使用,實(shí)例分析了PHP自定義RSA類實(shí)現(xiàn)加密與解密的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。

簡(jiǎn)單介紹RSA

RSA加密算法是最常用的非對(duì)稱加密算法,CFCA在證書(shū)服務(wù)中離不了它。但是有不少新手對(duì)它不太了解。下面僅作簡(jiǎn)要介紹。RSA是第一個(gè)比較完善的公開(kāi)密鑰算法,它既能用于加密,也能用于數(shù)字簽名。RSA以它的三個(gè)發(fā)明者Ron Rivest, Adi Shamir, Leonard Adleman的名字首字母命名,這個(gè)算法經(jīng)受住了多年深入的密碼分析,雖然密碼分析者既不能證明也不能否定RSA的安全性,但這恰恰說(shuō)明該算法有一定的可信性,目前它已經(jīng)成為最流行的公開(kāi)密鑰算法。RSA的安全基于大數(shù)分解的難度。其公鑰和私鑰是一對(duì)大素?cái)?shù)(100到200位十進(jìn)制數(shù)或更大)的函數(shù)。從一個(gè)公鑰和密文恢復(fù)出明文的難度,等價(jià)于分解兩個(gè)大素?cái)?shù)之積(這是公認(rèn)的數(shù)學(xué)難題)。

下面為具體類、實(shí)例:

?php 
 
/** 
 * RSA算法類 
 * 簽名及密文編碼:base64字符串/十六進(jìn)制字符串/二進(jìn)制字符串流 
 * 填充方式: PKCS1Padding(加解密)/NOPadding(解密) 
 * 
 * Notice:Only accepts a single block. Block size is equal to the RSA key size! 
 * 如密鑰長(zhǎng)度為1024 bit,則加密時(shí)數(shù)據(jù)需小于128字節(jié),加上PKCS1Padding本身的11字節(jié)信息,所以明文需小于117字節(jié) 
 * 
 * @author: ZHIHUA_WEI 
 * @version: 1.0.0 
 * @date: 2017/06/30 
 */ 
class RSA 
{ 
  private $pubKey = null; 
  private $priKey = null; 
 
  /** 
   * 構(gòu)造函數(shù) 
   * 
   * @param string 公鑰文件(驗(yàn)簽和加密時(shí)傳入) 
   * @param string 私鑰文件(簽名和解密時(shí)傳入) 
   */ 
  public function __construct($public_key_file = '', $private_key_file = '') 
  { 
    if ($public_key_file) { 
      $this->_getPublicKey($public_key_file); 
    } 
    if ($private_key_file) { 
      $this->_getPrivateKey($private_key_file); 
    } 
  } 
 
  // 私有方法 
  /** 
   * 自定義錯(cuò)誤處理 
   */ 
  private function _error($msg) 
  { 
    die('RSA Error:' . $msg); //TODO 
  } 
 
  /** 
   * 檢測(cè)填充類型 
   * 加密只支持PKCS1_PADDING 
   * 解密支持PKCS1_PADDING和NO_PADDING 
   * 
   * @param int 填充模式 
   * @param string 加密en/解密de 
   * @return bool 
   */ 
  private function _checkPadding($padding, $type) 
  { 
    if ($type == 'en') { 
      switch ($padding) { 
        case OPENSSL_PKCS1_PADDING: 
          $ret = true; 
          break; 
        default: 
          $ret = false; 
      } 
    } else { 
      switch ($padding) { 
        case OPENSSL_PKCS1_PADDING: 
        case OPENSSL_NO_PADDING: 
          $ret = true; 
          break; 
        default: 
          $ret = false; 
      } 
    } 
    return $ret; 
  } 
 
  private function _encode($data, $code) 
  { 
    switch (strtolower($code)) { 
      case 'base64': 
        $data = base64_encode('' . $data); 
        break; 
      case 'hex': 
        $data = bin2hex($data); 
        break; 
      case 'bin': 
      default: 
    } 
    return $data; 
  } 
 
  private function _decode($data, $code) 
  { 
    switch (strtolower($code)) { 
      case 'base64': 
        $data = base64_decode($data); 
        break; 
      case 'hex': 
        $data = $this->_hex2bin($data); 
        break; 
      case 'bin': 
      default: 
    } 
    return $data; 
  } 
 
  private function _getPublicKey($file) 
  { 
    $key_content = $this->_readFile($file); 
    if ($key_content) { 
      $this->pubKey = openssl_get_publickey($key_content); 
    } 
  } 
 
  private function _getPrivateKey($file) 
  { 
    $key_content = $this->_readFile($file); 
    if ($key_content) { 
      $this->priKey = openssl_get_privatekey($key_content); 
    } 
  } 
 
  private function _readFile($file) 
  { 
    $ret = false; 
    if (!file_exists($file)) { 
      $this->_error("The file {$file} is not exists"); 
    } else { 
      $ret = file_get_contents($file); 
    } 
    return $ret; 
  } 
 
  private function _hex2bin($hex = false) 
  { 
    $ret = $hex !== false  preg_match('/^[0-9a-fA-F]+$/i', $hex) ? pack("H*", $hex) : false; 
    return $ret; 
  } 
 
  /** 
   * 生成簽名 
   * 
   * @param string 簽名材料 
   * @param string 簽名編碼(base64/hex/bin) 
   * @return 簽名值 
   */ 
  public function sign($data, $code = 'base64') 
  { 
    $ret = false; 
    if (openssl_sign($data, $ret, $this->priKey)) { 
      $ret = $this->_encode($ret, $code); 
    } 
    return $ret; 
  } 
 
  /** 
   * 驗(yàn)證簽名 
   * 
   * @param string 簽名材料 
   * @param string 簽名值 
   * @param string 簽名編碼(base64/hex/bin) 
   * @return bool 
   */ 
  public function verify($data, $sign, $code = 'base64') 
  { 
    $ret = false; 
    $sign = $this->_decode($sign, $code); 
    if ($sign !== false) { 
      switch (openssl_verify($data, $sign, $this->pubKey)) { 
        case 1: 
          $ret = true; 
          break; 
        case 0: 
        case -1: 
        default: 
          $ret = false; 
      } 
    } 
    return $ret; 
  } 
 
  /** 
   * 加密 
   * 
   * @param string 明文 
   * @param string 密文編碼(base64/hex/bin) 
   * @param int 填充方式(貌似php有bug,所以目前僅支持OPENSSL_PKCS1_PADDING) 
   * @return string 密文 
   */ 
  public function encrypt($data, $code = 'base64', $padding = OPENSSL_PKCS1_PADDING) 
  { 
    $ret = false; 
    if (!$this->_checkPadding($padding, 'en')) $this->_error('padding error'); 
    if (openssl_public_encrypt($data, $result, $this->pubKey, $padding)) { 
      $ret = $this->_encode($result, $code); 
    } 
    return $ret; 
  } 
 
  /** 
   * 解密 
   * 
   * @param string 密文 
   * @param string 密文編碼(base64/hex/bin) 
   * @param int 填充方式(OPENSSL_PKCS1_PADDING / OPENSSL_NO_PADDING) 
   * @param bool 是否翻轉(zhuǎn)明文(When passing Microsoft CryptoAPI-generated RSA cyphertext, revert the bytes in the block) 
   * @return string 明文 
   */ 
  public function decrypt($data, $code = 'base64', $padding = OPENSSL_PKCS1_PADDING, $rev = false) 
  { 
    $ret = false; 
    $data = $this->_decode($data, $code); 
    if (!$this->_checkPadding($padding, 'de')) $this->_error('padding error'); 
    if ($data !== false) { 
      if (openssl_private_decrypt($data, $result, $this->priKey, $padding)) { 
        $ret = $rev ? rtrim(strrev($result), "\0") : '' . $result; 
      } 
    } 
    return $ret; 
  } 
} 

此為具體的RSA類

?php 
/** 
 * Author: Wei ZhiHua 
 * Date: 2017/6/30 0030 
 * Time: 上午 10:15 
 */ 
header('Content-Type:text/html;Charset=utf-8;'); 
include "RSA.php"; 
echo 'pre>'; 
 
$pubfile = 'D:\WWW\test\rsa_public_key.pem'; 
$prifile = 'D:\WWW\test\rsa_private_key.pem'; 
$rsa = new RSA($pubfile, $prifile); 
$rst = array( 
  'ret' => 200, 
  'code' => 1, 
  'data' => array(1, 2, 3, 4, 5, 6), 
  'msg' => "success", 
); 
$ex = json_encode($rst); 
//加密 
$ret_e = $rsa->encrypt($ex); 
//解密 
$ret_d = $rsa->decrypt($ret_e); 
echo $ret_e; 
echo 'pre>'; 
echo $ret_d; 
echo 'pre>';  
$a = 'test'; 
//簽名 
$x = $rsa->sign($a); 
//驗(yàn)證 
$y = $rsa->verify($a, $x); 
var_dump($x, $y); 
exit; 

您可能感興趣的文章:
  • 淺談PHP SHA1withRSA加密生成簽名及驗(yàn)簽
  • PHP7.1實(shí)現(xiàn)的AES與RSA加密操作示例
  • ThinkPHP實(shí)現(xiàn)的rsa非對(duì)稱加密類示例
  • PHP封裝的非對(duì)稱加密RSA算法示例
  • 基于PHP RSA密文過(guò)長(zhǎng)加密解密 越過(guò)1024的解決方法
  • PHP實(shí)現(xiàn)RSA加解密算法示例(生成密鑰位數(shù)為1024位的方法)
  • PHP檢測(cè)接口Traversable用法詳解
  • PHP實(shí)現(xiàn)的MD5結(jié)合RSA簽名算法實(shí)例
  • PHP實(shí)現(xiàn)RSA簽名生成訂單功能【支付寶示例】
  • php rsa 加密,解密,簽名,驗(yàn)簽詳解
  • php基于openssl的rsa加密解密示例
  • PHP rsa加密解密使用方法
  • php實(shí)現(xiàn)RSA加密類實(shí)例
  • 詳解PHP使用非對(duì)稱加密算法RSA

標(biāo)簽:太原 南昌 南京 曲靖 濱州 興安盟 白酒營(yíng)銷 株洲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP的RSA加密解密方法以及開(kāi)發(fā)接口使用》,本文關(guān)鍵詞  PHP,的,RSA,加密解密,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP的RSA加密解密方法以及開(kāi)發(fā)接口使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP的RSA加密解密方法以及開(kāi)發(fā)接口使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    精品日产卡一卡二卡麻豆| 韩国女主播成人在线| 成人午夜精品在线| 国产黄色片在线| 久久亚区不卡日本| 裸体健美xxxx欧美裸体表演| 中国美女乱淫免费看视频| 欧美一级久久久久久久大片| 亚洲成a天堂v人片| 伦理片一区二区| 欧美高清激情brazzers| 亚洲国产另类av| 99热超碰在线| 欧美一级一区二区| 欧美aaaaaa午夜精品| 91精品人妻一区二区| 欧美成人欧美edvon| 另类欧美日韩国产在线| 国精产品一区二区三区| 久久综合九色综合欧美亚洲| 激情深爱一区二区| 小早川怜子一区二区的演员表| 欧美国产综合一区二区| 成人国产精品免费网站| 一本色道久久综合亚洲91| 亚洲老妇xxxxxx| 亚洲最大视频网| 日韩视频免费直播| 黑人精品欧美一区二区蜜桃| 福利视频第一页| 综合av第一页| 亚洲av人人澡人人爽人人夜夜| 91麻豆精品国产91久久久资源速度| 天堂精品中文字幕在线| 中文字幕第20页| 欧美激情在线一区二区三区| 91小宝寻花一区二区三区| 欧美美女一区二区| 蜜臀av亚洲一区中文字幕| 美国精品一区二区| 亚洲精品免费一二三区| 在线天堂www在线国语对白| 精品区一区二区| 床上的激情91.| 欧美日韩亚洲另类| 蜜桃一区二区三区在线观看| 99自拍视频在线| 亚洲精品水蜜桃| 亚洲成人日韩在线| 欧美激情中文字幕一区二区| 中国老熟女重囗味hdxx| 欧美α欧美αv大片| 国产成人高清在线| 欧美日韩国产系列| 国产美女精品人人做人人爽| 91官网在线免费观看| 麻豆91精品视频| 日本久久电影网| 免费不卡在线视频| 日韩成人黄色片| 日韩精彩视频在线观看| 日本女人性生活视频| 亚洲一二三区不卡| 日本一道本视频| 亚洲国产一区视频| 黄大色黄女片18免费| 亚洲综合成人在线| 精品一区二区6| 亚洲一区二区高清| 欧美xxxx精品| 香蕉久久夜色精品国产使用方法 | 国产jjizz一区二区三区视频| 中文字幕亚洲区| 成人精品在线观看视频| 亚洲免费电影在线| 五月天精品视频| 亚洲成人动漫在线观看| 人人澡人人澡人人看| 丝袜亚洲另类欧美| 色香色香欲天天天影视综合网| 免费成人在线观看视频| 欧洲国内综合视频| 国产盗摄一区二区三区| 欧美一区二区三区视频| 99免费精品在线观看| 欧美精品一区二区三区很污很色的| 无人码人妻一区二区三区免费| 久久免费国产精品| 中文字幕乱码一区| 亚洲免费观看在线视频| 中文国语毛片高清视频| 蜜桃在线一区二区三区| 欧美日韩国产高清一区二区三区 | 狠狠色狠狠色合久久伊人| 欧美日韩国产大片| 成人国产精品免费观看视频| 久久精品视频免费| 波多野结衣av在线免费观看| 亚洲一区二区三区四区的| 国产三级国产精品国产国在线观看| 久久99国产精品久久99果冻传媒| 欧美日韩国产综合草草| 91原创在线视频| 日韩码欧中文字| 中文乱码字幕高清一区二区| 久久爱另类一区二区小说| 欧美精品久久99| 真实乱偷全部视频| 亚洲激情网站免费观看| 男人与禽猛交狂配| 国产成人精品免费| 国产欧美一区二区精品秋霞影院| 成年人在线免费看片| 蜜桃av一区二区三区| 欧美一区二区国产| 精品视频站长推荐| 亚洲国产精品天堂| 欧美性一二三区| 91丨porny丨在线| 亚洲人精品一区| 色综合天天做天天爱| 成人黄色小视频| 亚洲欧洲日产国产综合网| 国产一区二区播放| av亚洲精华国产精华精华| 亚洲欧洲日产国产综合网| 成人免费视频网站入口::| 成人免费视频视频在线观看免费| 日本一区二区三级电影在线观看 | 欧美人妇做爰xxxⅹ性高电影 | 成人免费在线播放视频| 91精品国产闺蜜国产在线闺蜜| 国产成人午夜片在线观看高清观看 | 欧美日韩生活片| 国产激情一区二区三区四区| 国产欧美一区二区三区在线老狼 | 国产精品女上位| 免费三级在线观看| 成人av动漫在线| 亚洲精品乱码久久久久| 欧美日韩一区三区四区| 荫蒂被男人添免费视频| 日韩电影一区二区三区四区| 精品国产免费一区二区三区四区| 国产人妻一区二区| 国产精品资源站在线| 国产精品人成在线观看免费| 精品一区在线观看视频| 91丝袜国产在线播放| 午夜国产不卡在线观看视频| 日韩欧美成人午夜| 99成人在线观看| 99久久精品99国产精品| 性久久久久久久久| 久久午夜电影网| 9999热视频| 人妻av一区二区| 国模大尺度一区二区三区| 国产精品国产三级国产aⅴ无密码| 色老汉一区二区三区| 在线观看一区二区三区四区| 青青草视频一区| 国产精品毛片久久久久久| 欧美系列在线观看| 亚洲做受高潮无遮挡| 成人永久免费视频| 亚洲午夜av在线| 久久久久免费观看| 色婷婷综合久久| 国产艳俗歌舞表演hd| 顶级嫩模精品视频在线看| 亚洲午夜在线视频| 2024国产精品| 91精品福利视频| 黄色正能量网站| 成人av综合在线| 日本视频免费一区| 中文一区在线播放| 91麻豆精品91久久久久同性| 欧美熟妇激情一区二区三区| 99久久精品一区二区| 蜜臀99久久精品久久久久久软件| 国产精品传媒入口麻豆| 欧美一区二区精品| 色综合久久久久综合体桃花网| 久久人人妻人人人人妻性色av| 国产xxx精品视频大全| 亚洲成人自拍网| 国产亚洲一区二区三区四区| 欧美日韩精品一区二区三区四区| 欧美人与性囗牲恔配| 黑人巨大猛交丰满少妇| 国内精品嫩模私拍在线| 亚洲午夜免费电影| 久久精品人人做人人爽97| 欧美日本视频在线| 国产传媒免费在线观看| 特大黑人巨人吊xxxx| thepron国产精品| 国产一区二区视频在线|