定制 fhooe/router 二次开发

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

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

fhooe/router

Composer 安装命令:

composer require fhooe/router

包简介

A simple object-oriented router for educational purposes.

README 文档

README

fhooe/router is a simple object-oriented router developed for PHP classes in the Media Technology and Design program at the University of Applied Sciences Upper Austria. It is primarily designed for educational purposes (learning the concept of routing and object-oriented principles). Its functionality is limited by design (e.g., only GET and POST methods are supported). Use it for "public" applications at your own risk.

Installation

The recommended way to use fhooe-router in your project is through Composer:

composer require fhooe/router

Alternatively, you can use the fhooe/router-skeleton project that gives you a fully working example built upon fhooe/router (including some simple views):

composer create-project fhooe/router-skeleton path/to/install

Composer will create a project in the path/to/install directory.

Basic Usage

Using a Router Object

  1. Instantiate the Router class.

    $router = new Router();

    Adding a logger: Pass an instance of a PSR-3 compatible logger application, e.g., Monolog, to receive predefined log messages about routes being added and executed. This can be useful to track what the Router is doing.

    $logger = new Logger("skeleton-logger");
    // add processors, formatters or handlers to the logger
    $router = new Router($logger);
  2. Define routes using the get() and post() methods. Supply a URI pattern to match against and a callback that is executed when the pattern and HTTP method match.

    $router->get("/", function () {
        // e.g., load a view
    });

    Placeholders: You can define route placeholders using curly brackets. The name of the placeholder will be available as a parameter in the callback, and the actual value in the URI will be its argument.

    $router->get("/product/{id}", function ($id) {
       // e.g., load a view to display the product
    });

    Optional parts: You can make route parts optional by putting them in square brackets. That way, a route will match both ways. This can be, for example, used to make a route work with or without a trailing slash.

    $router->get("/form[/]", function () {
       // e.g., load a view
    });
  3. Set a 404 callback to load a view or trigger behavior when no route matches.

    $router->set404Callback(function () {
        // e.g., load a 404 view
    });
  4. Optional: Define a base path if your application is not located in your server's document root.

    $router->basePath = "/path/to/your/files";
  5. Run the router. This will fetch the current URI, match it against the defined routes, and execute them if a match is found.

    $router->run();

Migrating from v2

  • setBasePath() and getBasePath() are replaced by the public basePath property:
    // v2
    $router->setBasePath("/path");
    // v3
    $router->basePath = "/path";
  • The static method Router::getRoute() has been removed. Use the object-oriented API with run() instead.

Contributing

If you'd like to contribute, please refer to CONTRIBUTING for details.

License

fhooe/router is licensed under the MIT license. See LICENSE for more information.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2021-12-16

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固