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

首頁 > 編程 > PHP > 正文

初識(shí) php 接口

2020-03-22 18:50:20
字體:
供稿:網(wǎng)友

這次的這篇文章介紹的是PHP接口的內(nèi)容,現(xiàn)在分享給大家,也給有需要幫助的朋友一個(gè)參考,大家一起過來看一看吧

一. 接口按請(qǐng)求人可以分為兩種:
  一種是被其他內(nèi)部項(xiàng)目調(diào)用的接口(包括js異步請(qǐng)求的接口和定時(shí)程序)。
  另一種是對(duì)外的接口,主要提供給外部開發(fā)者調(diào)用的。
  
  兩種接口最大區(qū)別就是,內(nèi)部接口不需要太嚴(yán)格的身份驗(yàn)證,而對(duì)外接口需要嚴(yán)格的身份驗(yàn)證,加密解密方式各種各樣,其中最常見最簡單的就是http basic驗(yàn)證,例如我們的大后臺(tái)彈出的賬號(hào)和密碼彈窗 就是用了basic驗(yàn)證,輸入賬號(hào)和密碼才能通過驗(yàn)證。但是如果內(nèi)部接口涉及到重要的操作,不希望被他人惡意請(qǐng)求的話,還是要做一點(diǎn)加密驗(yàn)證的。
  
二. 無論是哪一種接口,都應(yīng)該考慮到下面的問題:
1.安全。參數(shù)安全:這個(gè)我們有$_INPUT基本就足夠了。是否需要身份驗(yàn)證:如果只是內(nèi)部通知類/回調(diào)類的接口的話就算被惡意請(qǐng)求也不會(huì)影響數(shù)據(jù)正常,這種的話可以完全不做驗(yàn)證,舉個(gè)栗子,我做個(gè)一個(gè)同步訂單狀態(tài)的接口,里面的流程是,查詢訂單狀態(tài)有問題的訂單,然后更新這些訂單的狀態(tài)。這種接口不需要返回任何值,就算被壞人惡意調(diào)用也不會(huì)有毛線影響的,那就根本沒必要做身份驗(yàn)證了。所以這個(gè)是否加驗(yàn)證是按照接口實(shí)際邏輯決定的。

2.能否重復(fù)請(qǐng)求。例如某個(gè)接口是根據(jù)傳入的訂單號(hào),插入一條數(shù)據(jù),需要做好重復(fù)請(qǐng)求的判斷,避免插入多條數(shù)據(jù)。

三. 編寫接口規(guī)范
1. 用 try…catch…結(jié)構(gòu)去寫。(主要是 throw 可以隨時(shí)結(jié)束程序,這樣很爽~)
2. 返回狀態(tài)碼,不要返回success等于true或者false,如果要編寫文檔,關(guān)于不同錯(cuò)誤碼的含義也應(yīng)該寫明白,方便調(diào)用方查詢出錯(cuò)原因。
下面直接看栗子:

<?php    $code = 200; // 接口狀態(tài)碼     $name = trim($_INPUT['name']);    $age  = trim($_INPUT['age']);    if (empty($name))    {        $code = 401;        throw new Exception('名字不能為空');    }    if (!is_numeric($age))    {        $code = 402;        throw new Exception('年齡必須由數(shù)字組成');    }    $database_obj = new database_html' target='_blank'>class();    $res = $database_obj->save($name, $age);    if ( !$res )    {        $code = 403;        throw new Exception('保存數(shù)據(jù)失敗');    }            $msg = 'ok';    } catch ( Exception $e ) {        $msg = $e->getMessage();    }output_json($code,$data,$msg); // $data可以放置需要返回的數(shù)據(jù)// output_json函數(shù)在大function里面有~如果不想引入大function的話可以復(fù)制一份到自己項(xiàng)目// ========END=======?>

轉(zhuǎn)載自:https://www.cnblogs.com/xiaomendelu/p/5819708.html

一. 接口按請(qǐng)求人可以分為兩種:
  一種是被其他內(nèi)部項(xiàng)目調(diào)用的接口(包括js異步請(qǐng)求的接口和定時(shí)程序)。
  另一種是對(duì)外的接口,主要提供給外部開發(fā)者調(diào)用的。
  
  兩種接口最大區(qū)別就是,內(nèi)部接口不需要太嚴(yán)格的身份驗(yàn)證,而對(duì)外接口需要嚴(yán)格的身份驗(yàn)證,加密解密方式各種各樣,其中最常見最簡單的就是http basic驗(yàn)證,例如我們的大后臺(tái)彈出的賬號(hào)和密碼彈窗 就是用了basic驗(yàn)證,輸入賬號(hào)和密碼才能通過驗(yàn)證。但是如果內(nèi)部接口涉及到重要的操作,不希望被他人惡意請(qǐng)求的話,還是要做一點(diǎn)加密驗(yàn)證的。
  
二. 無論是哪一種接口,都應(yīng)該考慮到下面的問題:
1.安全。參數(shù)安全:這個(gè)我們有$_INPUT基本就足夠了。是否需要身份驗(yàn)證:如果只是內(nèi)部通知類/回調(diào)類的接口的話就算被惡意請(qǐng)求也不會(huì)影響數(shù)據(jù)正常,這種的話可以完全不做驗(yàn)證,舉個(gè)栗子,我做個(gè)一個(gè)同步訂單狀態(tài)的接口,里面的流程是,查詢訂單狀態(tài)有問題的訂單,然后更新這些訂單的狀態(tài)。這種接口不需要返回任何值,就算被壞人惡意調(diào)用也不會(huì)有毛線影響的,那就根本沒必要做身份驗(yàn)證了。所以這個(gè)是否加驗(yàn)證是按照接口實(shí)際邏輯決定的。

2.能否重復(fù)請(qǐng)求。例如某個(gè)接口是根據(jù)傳入的訂單號(hào),插入一條數(shù)據(jù),需要做好重復(fù)請(qǐng)求的判斷,避免插入多條數(shù)據(jù)。

三. 編寫接口規(guī)范
1. 用 try…catch…結(jié)構(gòu)去寫。(主要是 throw 可以隨時(shí)結(jié)束程序,這樣很爽~)
2. 返回狀態(tài)碼,不要返回success等于true或者false,如果要編寫文檔,關(guān)于不同錯(cuò)誤碼的含義也應(yīng)該寫明白,方便調(diào)用方查詢出錯(cuò)原因。
下面直接看栗子:

<?php    $code = 200; // 接口狀態(tài)碼     $name = trim($_INPUT['name']);    $age  = trim($_INPUT['age']);    if (empty($name))    {        $code = 401;        throw new Exception('名字不能為空');    }    if (!is_numeric($age))    {        $code = 402;        throw new Exception('年齡必須由數(shù)字組成');    }    $database_obj = new database_class();    $res = $database_obj->save($name, $age);    if ( !$res )    {        $code = 403;        throw new Exception('保存數(shù)據(jù)失敗');    }            $msg = 'ok';    } catch ( Exception $e ) {        $msg = $e->getMessage();    }output_json($code,$data,$msg); // $data可以放置需要返回的數(shù)據(jù)// output_json函數(shù)在大function里面有~如果不想引入大function的話可以復(fù)制一份到自己項(xiàng)目// ========END=======?>

轉(zhuǎn)載自:https://www.cnblogs.com/xiaomendelu/p/5819708.html

相關(guān)推薦:

php接口編程詳解

php接口如何正確使用

以上就是初識(shí) php 接口 的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注 其它相關(guān)文章!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 青田县| 康保县| 洪洞县| 新巴尔虎左旗| 文昌市| 商水县| 德兴市| 射阳县| 奉节县| 阜康市| 宜兰县| 宁夏| 方城县| 迭部县| 遵化市| 临武县| 河南省| 静安区| 墨竹工卡县| 包头市| 蛟河市| 永仁县| 淄博市| 长治市| 绿春县| 贵阳市| 监利县| 桐城市| 饶平县| 拜城县| 闽清县| 兴和县| 吕梁市| 德令哈市| 合肥市| 九龙县| 沧源| 龙泉市| 信阳市| 新郑市| 福清市|