承接 jonahh/omniroute 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

jonahh/omniroute

最新稳定版本:v1.2.11

Composer 安装命令:

composer require jonahh/omniroute

包简介

A simple framework to make URL Routing in PHP easier

README 文档

README

OmniRoute is a lightweight, flexible PHP routing library designed to simplify the management of routes in your PHP applications. It allows you to define routes, handle URL parameters with regular expressions, and manage error callbacks for common HTTP response codes.

Features

  • Route Registration: Easily register routes with specific HTTP methods and callbacks.
  • Prefix Support: Apply a prefix to a group of routes to organize and manage them efficiently.
  • Error Handling: Register custom callbacks for handling 404 Not Found and 405 Method Not Allowed errors.
  • Regular Expression Arguments: Support for dynamic URL parameters using regular expressions.
  • Sub-Router Integration: Include and register routes from external files for better modularization.

Installation

composer require jonahh/omniroute

Usage

Basic Route Registration

You can register a simple route by calling the add method:

use OmniRoute\Router;
require __DIR__.'/vendor/autoload.php';

Router::add('/home', function() {
    echo "Welcome to the homepage!";
});

Route with Parameters

To create a route with dynamic parameters, use placeholders wrapped in <: :>:

Router::add('/user/<:id:>', function($id) {
    echo "User ID: " . $id;
});

Prefixing Routes

You can group routes under a common prefix:

Router::registerPrefix('/api/v1');

Router::add('/users', function() {
    echo "Users endpoint";
});

All routes added after setting a prefix will automatically include it.

Registering Sub-Routers

For better modularization, you can load routes from external files:

Router::registerSubRouter('path/to/routes.php');

Setting allowed methods

You can set what methods are allowed for routes to be called:

Router::add('/api/post-only', function() {
    echo json_encode(["data"=>$data]);
}, ["POST"]);

Handling Errors

You can register custom error callbacks for 404 and 405 errors:

Router::registerErrorCallback(OMNI_404, function($path) {
    echo "Error 404: The path $path was not found.";
});

Router::registerErrorCallback(OMNI_405, function($path, $method) {
    echo "Error 405: The method $method is not allowed for $path.";
});

Running the Router

Finally, to execute the router and handle incoming requests, call the run method:

Router::run();

License

This package is open-source and available under the MIT License.

Author

This package is developed by Jonah

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-08-28