利用PHP如何寫APP接口詳解
搭建PHP環(huán)境
由于本人使用的電腦是Mac,因此推薦大家使用MAMP PRO這款軟件,不過是收費(fèi)版,相信不想花錢的大家會(huì)有辦法搞定的!
MAMP PRO這款軟件是集成環(huán)境軟件,已經(jīng)有apache、mysql、php了,具備運(yùn)行解析PHP的環(huán)境了!
如果不想使用集成環(huán)境,可以自己搭建。Mac自帶了apache和PHP環(huán)境的,只需要稍加配置一下就可以使用了,然后再安裝一下mysql就可以了!
大家可以看一下簡(jiǎn)單版本配置:Mac配置PHP環(huán)境 這篇文章。
啟動(dòng)服務(wù)器
這里是以MAMP PRO軟件為例,如何啟動(dòng)服務(wù)器。如下圖,我們假設(shè)服務(wù)地址為 www.api.com ,然后將項(xiàng)目目錄與這個(gè)服務(wù)地址關(guān)聯(lián)起來,看圖中右下角圈圈部分:

環(huán)境啟動(dòng)后,就可以在瀏覽器中直接輸入 www.api.com 運(yùn)行起來了!
開始GET接口
我們的空項(xiàng)目在首次運(yùn)行后,會(huì)自動(dòng)生成 index.php 這個(gè)文件,我們刪除里面的內(nèi)容,然后修改如下:
<?php $data = array( 'tid' => 100, 'name' => '標(biāo)哥的技術(shù)博客', 'site' => 'www.huangyibiao.com'); $response = array( 'code' => 200, 'message' => 'success for request', 'data' => $data, ); echojson_encode($response);
我們這里的結(jié)構(gòu)是日常App開發(fā)中最常見的返回?cái)?shù)據(jù)結(jié)構(gòu)了吧?通常都是狀態(tài)碼、狀態(tài)信息和客戶端業(yè)務(wù)數(shù)據(jù)。
PHP其實(shí)也好給力,聲明數(shù)組后,通過 json_encode 函數(shù)就可以輸出json格式數(shù)據(jù)了!
iOS調(diào)GET接口
我們有了服務(wù)器,也寫了接口了,那么客戶端如何請(qǐng)求又如何獲取數(shù)據(jù)呢?我們先來看一下最簡(jiǎn)單的GET請(qǐng)求例子,其中使用了HYBNetworking筆者的這個(gè)開源庫(kù):
NSString *url = @"http://www.api.com/index.php";
[HYBNetworkinggetWithUrl:urlrefreshCache:YESsuccess:^(id response) {
}fail:^(NSError *error) {
}];
我們看一下iOS客戶端的響應(yīng)結(jié)果:

從響應(yīng)結(jié)果可以看到,與我們服務(wù)器接口所返回的是一致的,看下圖在瀏覽器中訪問的效果:

PHP POST接口
假設(shè)我們要求傳參數(shù)type過來,而且要求是數(shù)值型,用于返回不同的數(shù)據(jù),當(dāng)我們做接口測(cè)試時(shí),就可以通過這么來干,就不需要等后臺(tái)給接口了!
<?php
$type = $_POST['type'];
$data = '';
if (isset($type) && is_numeric($type) && $type >= 0) {
if ($type == 1) {
$data = array(
'type' => $type,
'name' => '標(biāo)哥的技術(shù)博客',
'site' => 'www.huangyibiao.com');
} else if ($type == 2) {
$data = array(
'type' => $type,
'name' => '公眾號(hào):標(biāo)哥的技術(shù)博客',
'site' => 'weixin search: biaogedejishuboke');
}
$response = array(
'code' => 200,
'message' => 'success for request',
'data' => $data,
);
echojson_encode($response);
return;
}
$response = array(
'code' => 999,
'message' => 'argument error for request',
'data' => $data,
);
echojson_encode($response);
iOS調(diào)POST接口
下面是iOS客戶端如何調(diào)用剛才所寫的PHP POST接口,其中使用了HYBNetworking筆者的這個(gè)開源庫(kù):
NSString *url = @"http://www.api.com/index.php";
NSDictionary *params = @{@"type" : @(1)};
[HYBNetworkingpostWithUrl:urlrefreshCache:YESparams:paramssuccess:^(id response) {
}fail:^(NSError *error) {
}];
我們看看效果如下,可看到如愿地接收到了服務(wù)器返回的接口數(shù)據(jù)并解析出來了:

總結(jié)
本篇文章的內(nèi)容到這就基本結(jié)束了,相信大家若想學(xué)習(xí)它,一定會(huì)認(rèn)真去操作一遍的!今后會(huì)慢慢接觸它,慢慢掌握它,一定會(huì)讓你在工作上更加順利的!希望本文對(duì)大家能有所幫助。
相關(guān)文章
發(fā)布一個(gè)迷你php+AJAX聊天程序[聊天室]提供下載
發(fā)布一個(gè)迷你php+AJAX聊天程序[聊天室]提供下載...2007-07-07
PHP中使用memcache存儲(chǔ)session的三種配置方法
下面簡(jiǎn)單說下PHP項(xiàng)目分布式部署中,SESSION的同步方案中的一種,使用Memcache來存儲(chǔ)SESSION。并總結(jié)了三種配置方式,需要的朋友可以參考下2014-04-04
php array_values 返回?cái)?shù)組的值實(shí)例詳解
php array_values 函數(shù)用于返回?cái)?shù)組中所有的值,注意該函數(shù)將為新數(shù)組建立數(shù)組索引,原來的文字索引將不存在。本文章向大家講解array_values函數(shù)的基本語法及使用實(shí)例,需要的朋友可以參考下2016-11-11
thinkphp5框架調(diào)用其它控制器方法 實(shí)現(xiàn)自定義跳轉(zhuǎn)界面功能示例
這篇文章主要介紹了thinkphp5框架調(diào)用其它控制器方法 實(shí)現(xiàn)自定義跳轉(zhuǎn)界面功能,結(jié)合實(shí)例形式分析了thinkPHP5控制器調(diào)用、登陸判斷與界面跳轉(zhuǎn)相關(guān)操作技巧,需要的朋友可以參考下2019-07-07
php中serialize序列化與json性能測(cè)試的示例分析
本篇文章介紹了,在php中serialize序列化與json性能測(cè)試的示例分析。需要的朋友參考下2013-04-04

