定制 mateodioev/http-router 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

mateodioev/http-router

最新稳定版本:v1.2.2

Composer 安装命令:

composer require mateodioev/http-router

包简介

Simple route in php with support for vars in url

README 文档

README

⚠️ This project was made for educational purposes only. It is not intended to be used in production environments.

Usage

use Mateodioev\HttpRouter\exceptions\{HttpNotFoundException, RequestException};
use Mateodioev\HttpRouter\{Request, Response, Router};

$router = new Router();

// Register your endpoints here
$router->get('/', function (Request $r) {
    return Response::text('Hello world!');
});

$router->run();

Methods

You can use the Router::get, Router::post, Router::put, Router::patch and Router::delete methods to register your endpoints.

$router->myHttpMethod($uri, $callback);
  • $uri is the path of the endpoint.
  • $callback is the function that will be executed when the endpoint is requested. Each callback (action) must return an instance of the Mateodioev\HttpRouter\Response class or an InvalidReturnException will be thrown.

Static files

You can map all static files in a directory with the static method.

$router->static($baseUri, $path, $methods);
// Default methods are GET

Example:

tree
.
├── index.php
└── styles.css

1 directory, 2 files
$router->static('/docs', 'public/');

Now you can reach this uris

  • /docs/index.php
  • /docs/styles.css

Handling all HTTP methods

You can use the Router::all method to handle all HTTP methods with one callback.

$router->all($uri, $callback);

Path parameters

You can use path parameters in your endpoints. Path parameters are defined by a bracket followed by the name of the parameter.

/users/{id}

$router->get('/page/{name}', function (Request $r) {
    return Response::text('Welcome to ' . $r->param('name'));
});

Note: You can make a parameter optional by adding a question mark after the name of the parameter.

/users/{id}?

$router->get('/page/{name}?', function (Request $r) {
    $pageName = $r->param('name') ?? 'home'; // If the parameter is not present, the method return null
    return Response::text('Welcome to ' . $pageName);
});

Request data

You can get all data from the request with the following methods:

  • Request::method() returns the HTTP method of the request.
  • Request::uri() returns the URI of the request.
  • Request::uri() returns the URL of the request.
  • Request::param($name, $default = null) returns the value of the parameter with the name $name or null if the parameter is not present.
  • Request::params() return al the request URI parameters.
  • Request::headers() returns an array with all the headers of the request.
  • Request::body() returns the body of the request (from php://input).
  • Request::data() returns an array with all the data of the request. Use this when Content-Type is application/x-www-form-urlencoded or multipart/form-data.
  • Request::files() returns an array with all the files of the request.
  • Request::query() returns an array with all the query parameters from the uri.

TODO list:

  • Add support for middlewares.
  • Add support for custom error handlers.

统计信息

  • 总下载量: 42
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-06-16