php 使用 restler 框架构建 restfull api

时间:2023-08-07 10:07:20

php 使用 restler 框架构建 restfull api

restler 轻量级,小巧,构建restfull api非常方便!

官网:http://restler3.luracast.com/

目前最后的是3.0版本,我测试使用的是2.2版本;

一:安装restler2

1. 下载 https://github.com/Luracast/Restler/tree/2.2.0

2. exmple目录下放的是例子

3. 把restler 目录的所有文件放到你的web服务下;

二:开始创建restfull api

1. index.php

<?php

	//引入restler库
require_once './restler/restler.php'; $r = new Restler();
//配置支持的返回数据格式,json,xml等
$r->setSupportedFormats('JsonFormat');
//接口列表文件
$r->addAPIClass('api');
$r->handle(); ?>

2. 主接口文件 api.php, 上述1中的api表示的类名api

<?php

	//工具类
include 'util.php'; class api
{ //get 请求 /url/xml
public function getXml($deviceType)
{
if (!$deviceType) {
return array('xml' =>"error ");
} if ($deviceType=='1') { //return ios
return array('xml' =>"ios");
}
elseif ($deviceType=='2') { //return android
return array('xml' =>"android");
} elseif ($deviceType=='3') {
//return pc
return array('xml' =>"pc");
} else
{
return array('xml' =>"none support deviceType");
} } //post 请求,
public function postXXL($dev)
{
return returnXML($dev);
} //当类名与文件名相同时,可以不用 include 该类
public function getAAA()
{
$bd = new Baidu();
return $ret = array('site' => "baidu.com", );;
} } ?>

三:访问测试

1. api.php中所有public的方法,就是请求的方法,get或post 以方法名的前关键字为准;

如getXml方法,测试请求方式为

get http://127.0.0.1/tp/api/xml.josn

  或 http://127.0.0.1/tp/api/xml/1.json

  或http://127.0.0.1/tp/api/xml?deviceType=1

  后面的1对应getXml的请求字段 $deviceType

2. 其他函数同上

3. 如果要同时支持xml

如http://127.0.0.1/tp/api/xml/1.xml

http://127.0.0.1/tp/api/xml/1.json

在index.php配置

$r->setSupportedFormats('JsonFormat', 'XmlFormat');

更多:http://restler3.luracast.com/examples/index.html