基于 Slim + Laravel Eloquent 的 RESTful API 框架。
由于 Laravel 的验证依赖了很多 Symfony 的组件,所以我简化了一个版本 (validation),并引用到这个项目中。
请使用 composer 安装
git clone https://github.com/overtrue/rester
cd rester
composer install
虚拟机配置文件 vhost
app/routes.php
<?php
$app->get('/', function(){
return json_encode(['hello' => 'world!']);
});
或者也可以使用控制器:
$app->get('/', 'HomeController:index'); //调用HomeController的index方法
更多路由的使用请阅读 Slim 官方文档:http://docs.slimframework.com/#Routing-Overview
<?php
/**
* 演示控制器
*/
class HomeController extends Controller
{
public function index() {
return $this->json(['app' => 'Rester', 'message' => 'Hello world!']);
}
//...
}
控制器里有用的方法有:
-
$this->init()
会在项目初始化完成后首先调用,可以用来做一些初始化或者每个方法都需要用到的动作,比如用户授权。 -
$this->json(mixed $data [, int $status = 200])
输出json
格式数据,第二个参数为状态码。 -
$this->jsonp(mixed $data [, string $callback = ''])
输出jsonp
数据,第二个参数为回调函数名,可选,为空默认从$_GET
读取callback
, 如果最终获取不到callback
,输出等于$this->json
。 -
$this->validate(array $input, array $rules [, boolean $return = false])
数据验证,默认验证失败主动返回错误json
输出并停止往下运行,当$return = true
时不停止运行,返回验证失败消息。 -
$this->error(string $message, int $status [, array $errors = []])
输出错误 json,$errors
为错误明细,通常为数组,可选。
更多数据验证规则请参阅:http://laravel.com/docs/4.2/validation
想知道如何从零开始构建 PHP 扩展包?
请关注我的实战课程,我会在此课程中分享一些扩展开发经验 —— 《PHP 扩展包实战教程 - 从入门到发布》
MIT