国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > PHP > 正文

PHP開發(fā)api接口安全驗(yàn)證的實(shí)例講解

2024-05-05 00:02:46
字體:
供稿:網(wǎng)友

php的api接口

在實(shí)際工作中,使用PHP寫api接口是經(jīng)常做的,PHP寫好接口后,前臺(tái)就可以通過鏈接獲取接口提供的數(shù)據(jù),而返回的數(shù)據(jù)一般分為兩種情況,xml和json,在這個(gè)過程中,服務(wù)器并不知道,請(qǐng)求的來源是什么,有可能是別人非法調(diào)用我們的接口,獲取數(shù)據(jù),因此就要使用安全驗(yàn)證。

驗(yàn)證原理

示意圖

php,api接口,安全驗(yàn)證

原理

從圖中可以看得很清楚,前臺(tái)想要調(diào)用接口,需要使用幾個(gè)參數(shù)生成簽名。

時(shí)間戳:當(dāng)前時(shí)間

隨機(jī)數(shù):隨機(jī)生成的隨機(jī)數(shù)

口令:前后臺(tái)開發(fā)時(shí),一個(gè)雙方都知道的標(biāo)識(shí),相當(dāng)于暗號(hào)

算法規(guī)則:商定好的運(yùn)算規(guī)則,上面三個(gè)參數(shù)可以利用算法規(guī)則生成一個(gè)簽名。

前臺(tái)生成一個(gè)簽名,當(dāng)需要訪問接口的時(shí)候,把時(shí)間戳,隨機(jī)數(shù),簽名通過URL傳遞到后臺(tái)。后臺(tái)拿到時(shí)間戳,隨機(jī)數(shù)后,通過一樣的算法規(guī)則計(jì)算出簽名,然后和傳遞過來的簽名進(jìn)行對(duì)比,一樣的話,返回?cái)?shù)據(jù)。

算法規(guī)則

在前后臺(tái)交互中,算法規(guī)則是非常重要的,前后臺(tái)都要通過算法規(guī)則計(jì)算出簽名,至于規(guī)則怎么制定,看你怎么高興怎么來。

我這個(gè)算法規(guī)則是

1 時(shí)間戳,隨機(jī)數(shù),口令按照首字母大小寫順序排序

2 然后拼接成字符串

3 進(jìn)行sha1加密

4 再進(jìn)行MD5加密

5 轉(zhuǎn)換成大寫。

前臺(tái)

這里我并沒有實(shí)際的前臺(tái),直接使用一個(gè)PHP文件代替前臺(tái),然后通過CURL模擬GET請(qǐng)求。我使用的是TP框架,URL格式是pathinfo格式。

源代碼

<?php/** * Created by PhpStorm. * User: Administrator * Date: 2017/3/16 0016 * Time: 15:56 */namespace Client/Controller;use Think/Controller;class ClientController extends Controller{ const TOKEN = 'API'; //模擬前臺(tái)請(qǐng)求服務(wù)器api接口 public function getDataFromServer(){  //時(shí)間戳  $timeStamp = time();  //隨機(jī)數(shù)  $randomStr = $this -> createNonceStr();  //生成簽名  $signature = $this -> arithmetic($timeStamp,$randomStr);  //url地址  $url = "http://www.apitest.com/Server/Server/respond/t/{$timeStamp}/r/{$randomStr}/s/{$signature}";  $result = $this -> httpGet($url);  dump($result); } //curl模擬get請(qǐng)求。 private function httpGet($url){  $curl = curl_init();  //需要請(qǐng)求的是哪個(gè)地址  curl_setopt($curl,CURLOPT_URL,$url);  //表示把請(qǐng)求的數(shù)據(jù)已文件流的方式輸出到變量中  curl_setopt($curl,CURLOPT_RETURNTRANSFER,1);  $result = curl_exec($curl);  curl_close($curl);  return $result; } //隨機(jī)生成字符串 private function createNonceStr($length = 8) {  $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";  $str = "";  for ($i = 0; $i < $length; $i++) {   $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);  }  return "z".$str; } /**  * @param $timeStamp 時(shí)間戳  * @param $randomStr 隨機(jī)字符串  * @return string 返回簽名  */ private function arithmetic($timeStamp,$randomStr){  $arr['timeStamp'] = $timeStamp;  $arr['randomStr'] = $randomStr;  $arr['token'] = self::TOKEN;  //按照首字母大小寫順序排序  sort($arr,SORT_STRING);  //拼接成字符串  $str = implode($arr);  //進(jìn)行加密  $signature = sha1($str);  $signature = md5($signature);  //轉(zhuǎn)換成大寫  $signature = strtoupper($signature);  return $signature; }}

服務(wù)器端

接受前臺(tái)數(shù)據(jù)進(jìn)行驗(yàn)證

源代碼

<?php/** * Created by PhpStorm. * User: Administrator * Date: 2017/3/16 0016 * Time: 16:01 */namespace Server/Controller;use Think/Controller;class ServerController extends Controller{ const TOKEN = 'API'; //響應(yīng)前臺(tái)的請(qǐng)求 public function respond(){  //驗(yàn)證身份  $timeStamp = $_GET['t'];  $randomStr = $_GET['r'];  $signature = $_GET['s'];  $str = $this -> arithmetic($timeStamp,$randomStr);  if($str != $signature){   echo "-1";   exit;  }  //模擬數(shù)據(jù)  $arr['name'] = 'api';  $arr['age'] = 15;  $arr['address'] = 'zz';  $arr['ip'] = "192.168.0.1";  echo json_encode($arr); } /**  * @param $timeStamp 時(shí)間戳  * @param $randomStr 隨機(jī)字符串  * @return string 返回簽名  */ public function arithmetic($timeStamp,$randomStr){  $arr['timeStamp'] = $timeStamp;  $arr['randomStr'] = $randomStr;  $arr['token'] = self::TOKEN;  //按照首字母大小寫順序排序  sort($arr,SORT_STRING);  //拼接成字符串  $str = implode($arr);  //進(jìn)行加密  $signature = sha1($str);  $signature = md5($signature);  //轉(zhuǎn)換成大寫  $signature = strtoupper($signature);  return $signature; }}

結(jié)果

string(57) "{"name":"api","age":15,"address":"zz","ip":"192.168.0.1"}"

總結(jié)

這種方法只是其中的一種方法,其實(shí)還有很多方法都是可以進(jìn)行安全驗(yàn)證的。

以上這篇PHP開發(fā)api接口安全驗(yàn)證的實(shí)例講解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到PHP教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 太康县| 达州市| 民勤县| 温宿县| 安庆市| 宜都市| 西丰县| 沂南县| 绥中县| 原平市| 邢台县| 鄂尔多斯市| 布尔津县| 安乡县| 延津县| 南丰县| 武功县| 福州市| 自治县| 青阳县| 积石山| 诏安县| 通州市| 山阳县| 高要市| 株洲市| 新竹县| 新巴尔虎右旗| 彰化市| 武宣县| 莱阳市| 拜城县| 肥西县| 杨浦区| 中超| 江达县| 衡东县| 皮山县| 曲阳县| 游戏| 富川|