phore/micro-app
最新稳定版本:v0.3.1
Composer 安装命令:
composer require phore/micro-app
包简介
Micro framework for rest api webservices
README 文档
README
This documentation is written along the guidelines of educational grade documentation discussed in the infracamp project. Please ask and document issues.
Goals
- Minimal Footprint
- No external dependencies
- Clear and small stack trace
- Fluent Api
- Role-Based Authentication
Quicklinks
- Assets
- Authentication
- Session
- OAuth
- Firewall ACL
Naming conventions
Classes for micro-app and libraries are not prefixed with phore_ for convenience.
(It's not framework for framework stuff)
Quickstart
index.php:
$app = new App(); $app->router ->onGet("/", // Define a Action for HTTP-GET-Requests to / function() { return "Hello world"; // Important: Return true if output was already sent. } ); $app->serve(); // Run the App
Installation
We suggest using composer:
composer require phore/micro-app
Routing (Example)
Define routes (Path) and connect them to controller functions:
-
Execute the function if the browser hits
http://domain.xy/hello/world:$app->router->onGet("/hello/world", function() { echo "Hello World"; return true; });
-
Define Parameters (Prefix
:) and optional parameters (?) in Routes:$app->router->onGet("/api/create/:userId/:userName?", function(RouteParams $routeParams) { echo "Hello {$routeParams->get("userId")} - {$routeParams->get("userName", 'Default Username')}"; return true; });
$routeParamsis automaticly generated by Dependency injection. -
Delegate a request to a separate class: see Example
$app->router->delegate("/admin/*", AdminController::class);
-
Add a controller Class:
class ActionCtrl { const ROUTE = "/v1/some/route" public function on_get(){} } $app->addCtrl(ActionCtrl::class);
Parameters at controller function are generated by Dependency Injection and may contain any service defined in DiContainer.
Request specific parameters are:
| Parameter Name | ClassName | Description |
|---|---|---|
$request |
Request |
The full request object |
$post |
Post |
Post data |
$get |
Get |
Get data (Query Params) |
$body |
Body |
Body object |
$files |
Files |
|
$route |
Route |
The current route object |
$params |
Params |
Container with QueryParameters |
$routeParams |
RouteParams |
Container with parameters |
$GET |
QueryParams |
Query parameters |
$POST |
QueryParams |
Parameters send by HTTP-POST |
Dependency Injection
The app-class is a dependency injection container. You can register
values or services using the define() method.
-
Define a value to property
version:$app->define("version", new DiValue("1.0.1")); echo $app->version;
-
Define a factory to property
configFile:$app->define("configFile", new DiService(function() { return file_get_contents("config-file.json") }); echo $app->configFile;
Error Handling
The system has build-in functions for error-handling:
- Activate
jsonerror/exception handling:$app->setOnExceptionHandler(new JsonExceptionHandler());
API Usage: Default Result Handler
Instead of formating the Result your own, the framework uses a
result-handler to format results returned by return in controller.
$app->setDefaultResultHandler(new JsonResultHandler());
in the controller you can then just return the data:
$app->get("/", function() { return ["data"=>"someData"]; }
统计信息
- 总下载量: 5.87k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 5
- 依赖项目数: 8
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2018-06-18