静态路由

静态路由是直接通过URl映射,因此效率高,但作用也是有限的。

URL解析规则

仅支持PATHINFO模式的 URL 解析,且与控制器名称(方法)保持一致,控制器搜索规则为优先完整匹配模式

解析规则

在没有路由干预的情况下,内置的解析规则支持无限级嵌套目录,如下方两个例子所示

  • http://serverName/api/auth/login

    对应执行的方法为 \App\HttpController\Api\Auth::login()

  • http://serverName/a/b/c/d/f

    • 如果 f 为控制器名,则执行的方法为 \App\HttpController\A\B\C\D\F::index()

    • 如果 f 为方法名,则执行的方法为 \App\HttpControllers\A\B\C\D::f()

    • 如果最后的路径为index时,底层会自动忽略,并直接调用控制器的默认方法(也就是index)

解析层级

理论上 EasySwoole 支持无限层级的URL -> 控制器映射,但出于系统效率和防止恶意 URL 访问, 系统默认为3级,若由于业务需求,需要更多层级的URL映射匹配,请于框架初始化事件中向 DI 注入常量SysConst::HTTP_CONTROLLER_MAX_DEPTH ,值为 URL 解析的最大层级,如下代码,允许 URL 最大解析至5层

public static function initialize()
{
    Di::getInstance()->set(SysConst::HTTP_CONTROLLER_MAX_DEPTH,5);
}

特殊情况

当控制器和方法都为index时,可直接忽略不写

  • 如果方法为index,则可以忽略:
    如果对应执行方法名为 \App\HttpController\Api\User::index() url可直接写 http://serverName/api/User

  • 如果控制器和方法都为Index,则可以忽略 如果对应执行方法名为 \App\HttpController\Index::index() url可直接写 http://serverName/

  • index忽略规则理论支持无限层级,根据解析层级最大进行逐层查找

注意,EasySwoole的URL路径区分大小写,控制器首字母支持小写转换