phore/micro-app 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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;
    });

    $routeParams is 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 json error/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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2018-06-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固