PHP實現Restful風格的API(轉)

Restful是一種設計風格而不是標準,好比一個接口本來是這樣的:程序員

http://www1.qixoo.com/user/view/id/1
表示獲取id爲1的用戶信息,若是使用Restful風格,能夠變成這樣:json

http://www1.qixoo.com/user/1
能夠很明顯的看出這樣作的好處:安全

一、更簡潔的URL,對程序員友好框架

二、不暴露內部代碼結構,更安全設計

那麼,如何實現這個接口呢?首先,咱們須要接收到/user/1部分。code

$path = $_SERVER[‘PATH_INFO‘];
$arr = explode(‘/‘,$path);接口

print_r($arr);
獲得下面的結果:基礎

Array
(
[0] => 
[1] => User
[2] => 1
)
獲取到了參數,下面的操做就很簡單了:原理

if($arr[1] == ‘user‘){

$model = new UserModel();
$id = $arr[2];

//讀取用戶信息
$user_info = $model->find($id);

echo json_encode($user_info);

}
這樣,咱們就實現了一個Restful風格的API。select

下面,咱們再看如何實現讀取用戶列表的接口,傳統方式:

http://www1.qixoo.com/user/list
使用Restful風格,能夠更加簡潔:

http://www1.qixoo.com/user
和讀取用戶信息的區別是,user後面沒有id,因此咱們能夠在讀取部分的基礎上作一下修改:

if($arr[1] == ‘user‘){

$model = new UserModel();
$id = $arr[2];

if($id){

//讀取用戶信息
$user_info = $model->find($id);
echo json_encode($user_info);

}else{

//讀取用戶列表 

$user_list = $model->select();
echo json_encode($user_list);
}
}
這樣就實現了讀取用戶列表的接口。

下面再看如何實現增長用戶的接口,傳統方式:

http://www1.qixoo.com/user/add
Restful風格:

http://www1.qixoo.com/user
和讀取用戶列表的接口是同樣的,怎麼區分呢?其實很簡單,讀取是GET請求,而增長是POST請求,用戶信息都存在POST參數中,因此能夠對代碼進行下面的修改:

if($arr[1] == ‘user‘){

$model = new UserModel();
$id = $arr[2];

if($id){

//讀取用戶信息
$user_info = $model->find($id);
echo json_encode($user_info);

}else{

if(IS_POST){

//增長用戶 
$res = $model->add($_POST);
if($res){
echo ‘success‘;
}else{
echo ‘fail‘;
}

}else{
//讀取用戶列表 

$user_list = $model->select();
echo json_encode($user_list);
}
}
}
一樣的接口,能夠依據HTTP請求方式來執行不一樣的邏輯。

這就是實現Restful風格API的核心思路,依次類推,咱們能夠實現編輯用戶接口和刪除用戶接口:

http://www1.qixoo.com/user/1
只要使用不一樣的請求方式,就能區分開了。咱們能夠用PUT請求來執行編輯操做,用DELETE請求來執行刪除操做。

具體代碼就不寫了,有興趣的朋友能夠本身嘗試實現如下。

在ThinkPHP框架中也提供了對Restful風格的支持,原理也是相似的。

總結一下,Restful風格就是,使用簡單的URL和HTTP請求方式來實現接口。

相關文章
相關標籤/搜索