亚洲精品成人_精品成人一区_999视频在线播放_免费黄色在线_亚洲成人久久久_久久www免费视频

動態(tài)路由

動態(tài)路由就是把 url 的請求優(yōu)雅地對應(yīng)到你想要執(zhí)行的操作方法。 EasySwoole 的動態(tài)路由是基于 FastRoute 實現(xiàn),與其路由規(guī)則保持一致。

示例代碼

新建文件 App\HttpController\Router.php,(從框架 3.4.x 版本開始,用戶可能不需要新建此文件。如果用戶在安裝時選擇了釋放 Router.php 則不必新建,如果沒有,請自行新建):

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/user', '/user');

        $routeCollector->get('/user1', '/User/user1');

        $routeCollector->get('/rpc', '/Rpc/index');

        $routeCollector->get('/', function (Request $request, Response $response) {
            $response->write('this is router home');
            return false; // 不再往下請求,結(jié)束此次響應(yīng)
        });
        // $routeCollector->get('/', '/index');

        $routeCollector->get('/test', function (Request $request, Response $response) {
            $response->write('this is router test.');
            return '/child';
        });
        $routeCollector->get('/child', function (Request $request, Response $response) {
            $response->write('this is router child.');
            return false; // 不再往下請求,結(jié)束此次響應(yīng)
        });

        $routeCollector->get('/mtest1', '/a/b/c/d/index/index');
        $routeCollector->get('/mtest2', '/A/B/C/D/Index/index');

        // 從 `easyswoole/http 2.x 版本開始,綁定的參數(shù)將由框架內(nèi)部進行組裝到框架的 `Context(上下文)` 數(shù)據(jù)之中,具體使用請看下文。
        $routeCollector->get('/user/{id:\d+}', function (Request $request, Response $response) {
            // 獲取 id 參數(shù)
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id'];
            $response->write("this is router user, id is {$id}");
            return false; // 不再往下請求,結(jié)束此次響應(yīng)
        });
    }
}

創(chuàng)建路由

EasySwoole 路由接受一個 URI 和一個 Handler(這個 Handler 可以是一個 閉包callback 或者一個 字符串string),提供了一個簡單優(yōu)雅的方法來定義路由和行為,而不需要復(fù)雜的路由配置文件:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/greeting', function (Request $request, Response $response) {
            $response->write('Hello World');
            return false;
        });
    }
}

從上面可以看到,創(chuàng)建匹配 HTTP 請求方法 GET 的路由的方法很簡單,如下:

$routeCollector->get($uri, $handler);
  • $uri字符串string 格式
  • $handler閉包callback 或者 字符串string 格式,當(dāng)為 字符串 格式時則表示是與控制類的 action 相關(guān)聯(lián)。

針對上述方法的參數(shù)的含義說明如下:

  • 當(dāng) $handler/xxx 時,則對應(yīng)關(guān)聯(lián)執(zhí)行 App\HttpController\Index.php 類的 xxx() 方法。
  • 當(dāng) $handler/xxx/xxx/xxx/xxx 或者 /Xxx/Xxx/Xxx/xxx 時,二者其實等價,都對應(yīng)關(guān)聯(lián)執(zhí)行 App\HttpController\Xxx\Xxx\Xxx.php 類的 xxx() 方法。
  • 當(dāng) $handler/xxx/xxx/xxx/Xxx 或者 /Xxx/Xxx/Xxx/Xxx 時,二者也等價,都對應(yīng)關(guān)聯(lián)執(zhí)行 App\HttpController\Xxx\Xxx\Xxx.php 類的 Xxx() 方法。

綜上所述,其實 $handler 中最后一個 / 后的名稱一定為控制器類的 action 名稱 (且不會轉(zhuǎn)換大小寫),前面的則為對應(yīng)控制器所在命名空間及路徑,控制器名稱及文件夾名稱請務(wù)必以 大寫字母 開頭,否則路由將不能匹配到對應(yīng)的執(zhí)行方法。而對于 $uri 則沒有特殊要求。$handler 指定路由匹配成功后需要處理的方法,可以傳入一個閉包,當(dāng)傳入閉包時一定要 注意處理完成之后要處理結(jié)束響應(yīng),否則請求會繼續(xù) Dispatch 尋找對應(yīng)的控制器來處理,當(dāng)然如果利用這一點,也可以對某些請求進行處理后再交給控制器執(zhí)行邏輯。

用戶在新建控制器類和文件夾時,請使用 大駝峰法 命名。如果使用回調(diào)函數(shù)方式處理路由,return false; 代表不繼續(xù)往下請求。

默認(rèn)路由文件

默認(rèn)路由文件位于 App\HttpController 目錄的 Router.php 文件。在 Router.php 文件可以定義我們常用的路由。對于大多數(shù)應(yīng)用程序,也都是在 Router.php 文件定義路由。例如,你可以在瀏覽器中輸入 http://example.com/user 來訪問以下路由:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        // 下面定義的路由將 /user URI 與 App\HttpController\User 類 的 index() action 相關(guān)聯(lián)
        $routeCollector->get('/user', '/User/index');
    }
}

添加額外的路由文件

上述已經(jīng)提到 EasySwoole 框架默認(rèn)的路由文件為 App\HttpController 目錄的 Router.php 文件。當(dāng)我們想要添加額外的路由文件時,我們可以在 App 目錄新建一個目錄 Route 用來統(tǒng)一存放額外的路由,然后在 App\HttpController 目錄的 Router.php 文件中進行注冊。如下:

App\Route 目錄(前提:已自行創(chuàng)建好此目錄),新增 ApiRouter.php 文件,該文件內(nèi)容如下:

<?php
namespace App\Route;

use FastRoute\RouteCollector;

class ApiRouter
{
    public function initialize(RouteCollector &$routeCollector)
    {
        $routeCollector->addGroup('/api/v1/user', function (RouteCollector $routeCollector) {
            $routeCollector->post('/create', '/Api/User/create');
            $routeCollector->post('/delete/{id:\d+}', '/Api/User/delete');
            $routeCollector->post('/update/{id:\d+}', '/Api/User/update');
            $routeCollector->post('/query', '/Api/User/query');
        });
    }
}

App\HttpController 目錄的 Router.php 文件中進行注冊額外的路由:

<?php
namespace App\HttpController;

use App\Route\ApiRouter;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        // 注冊額外的路由
        (new ApiRouter())->initialize($routeCollector);
    }
}

依賴注入

在路由的回調(diào)方法中,框架會自動將當(dāng)前的 HTTP 請求和 HTTP 響應(yīng)注入依賴到你的路由回調(diào)中:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/greeting', function (Request $request, Response $response) {
            $response->write('Hello World');
            return false;
        });
    }
}

注入的 HTTP 請求對象可用來讀取請求參數(shù)等,注入的 HTTP 響應(yīng)對象可用來指定返回給客戶端的響應(yīng)內(nèi)容。

匹配 HTTP 方法

路由器允許你注冊能響應(yīng)任何 HTTP 請求的路由

$routeCollector->get($uri, $handler);
// 等價于
$routeCollector->addRoute('GET', $uri, $handler);

$routeCollector->post($uri, $handler);
// 等價于
$routeCollector->addRoute('POST', $uri, $handler);

$routeCollector->put($uri, $handler);
// 等價于
$routeCollector->addRoute('PUT', $uri, $handler);

$routeCollector->patch($uri, $handler);
// 等價于
$routeCollector->addRoute('PATCH', $uri, $handler);

$routeCollector->delete($uri, $handler);
// 等價于
$routeCollector->addRoute('DELETE', $uri, $handler);

$routeCollector->head($uri, $handler);
// 等價于
$routeCollector->addRoute('HEAD', $uri, $handler);

$routeCollector->addRoute('OPTIONS', $uri, $handler);

有的時候你可能需要注冊一個可響應(yīng)多種 HTTP 請求的路由,這時你可以使用 addRoute 方法注冊一個實現(xiàn)響應(yīng)多種 HTTP 請求的路由:

$routeCollector->addRoute(['GET', 'POST'], $uri, $handler);

addRoute 方法說明

方法格式如下:

$routeCollector->addRoute($http, $uri, $handler);
  • $httpMethdHTTP 請求方法)參數(shù)必須是 大寫HTTP 請求方法字符串或者字符串?dāng)?shù)組,如 GETPOSTPUTPATCHDELETEHEADOPTIONS

  • $uri 參數(shù)需要傳入一個 URI,格式如: /路徑名稱/{參數(shù)名稱:匹配規(guī)則},占位符 : 用于限制約束路由參數(shù)。

  • $handler 參數(shù)需要傳入一個字符串或閉包,上述已說明,就不做過多闡述。

示例如下:

$routeCollector->addRoute('GET', $uri, $handler);
$routeCollector->addRoute(['GET', 'POST'], $uri, $handler);

路由參數(shù)

必需參數(shù)

有時你將需要捕獲路由內(nèi)的 URI 段。例如,你可能需要從 URL 中捕獲用戶的 ID。你可以通過定義路由參數(shù)來做到這一點:

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/user/{id}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id'];
            $response->write("User {$id}");
            return false;
        });
    }
}

也可以根據(jù)你的需要在路由中定義多個參數(shù):

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/posts/{post}/comments/{comment}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $post = $context['post'];
            $comment = $context['comment'];
            $response->write("post: {$post}, comment: {$comment}");
            return false;
        });
    }
}

路由的參數(shù)通常都會被放在 {} ,并且參數(shù)名只能為字母。

可選參數(shù)

有時,你可能需要指定一個路由參數(shù),但你希望這個參數(shù)是可選的。你可以在加上 [] 標(biāo)記將 /{參數(shù)} 包含起來來實現(xiàn):

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/user[/{name}]', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $name = $context['name'] ?? '';
            $response->write("name: {$name}");
            return false;
        });

        // 上述路由等價于下面2個路由
        $routeCollector->get('/user', function (Request $request, Response $response) {
            // your code
            return false;
        });
        $routeCollector->get('/user/{name}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $name = $context['name'];
            $response->write("name: {$name}");
            return false;
        });

        $routeCollector->get('/user[/{id}[/{name}]]', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $name = $context['name'] ?? '';
            $response->write("name: {$name}");
            return false;
        });
    }
}

獲取路由參數(shù)

從 Context 中獲取路由參數(shù)(路由參數(shù)的默認(rèn)獲取機制)

可以從 \EasySwoole\Component\Context\ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY) 上下文中獲取路由參數(shù)。此配置項是easyswoole/http 2.x 版本開始的默認(rèn)配置。如需設(shè)置需在 App\HttpController\Router.php 添加如下代碼:

$this->parseParams(\EasySwoole\Http\AbstractInterface\AbstractRouter::PARSE_PARAMS_IN_CONTEXT);

具體使用示例:

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        // /user/1
        $routeCollector->get('/user/{id}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id']; // 1
            $response->write("id: {$id}");
            return false;
        });
    }
}

從 Query Param 中獲取路由參數(shù)

如果想從 Query Param 中獲取路由參數(shù),可使用這個 $this->request()->getQueryParams() 方法進行獲取,但是需要先在 App\HttpController\Router.php 中進行設(shè)置:

$this->parseParams(\EasySwoole\Http\AbstractInterface\AbstractRouter::PARSE_PARAMS_IN_GET);

具體設(shè)置如下:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $this->parseParams(Router::PARSE_PARAMS_IN_GET);

        // /user/1
        $routeCollector->get('/user/{id:\d+}', function (Request $request, Response $response) {
            $id = $request->getQueryParam('id'); // 1
            $response->write("id: {$id}");
            return false;
        });
    }
}

從 POST 請求參數(shù)中獲取路由參數(shù)

如果想從 POST 請求參數(shù)中獲取路由參數(shù),可使用這個 $this->request()->getParsedBody() 方法進行獲取,但是需要先在 App\HttpController\Router.php 中進行設(shè)置:

$this->parseParams(\EasySwoole\Http\AbstractInterface\AbstractRouter::PARSE_PARAMS_IN_POST);

具體設(shè)置如下:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $this->parseParams(Router::PARSE_PARAMS_IN_POST);

        // /user/1
        $routeCollector->get('/user/{id:\d+}', function (Request $request, Response $response) {
            $id = $request->getParsedBody('id'); // 1
            $response->write("id: {$id}");
            return false;
        });
    }
}

NONE

不獲取路由參數(shù)時,可以在 App\HttpController\Router.php 中進行設(shè)置:

$this->parseParams(\EasySwoole\Http\AbstractInterface\AbstractRouter::PARSE_PARAMS_NONE);

注意:以上 4 種設(shè)置,用戶只能設(shè)置 1 種。Router 默認(rèn)使用的設(shè)置是從請求上下文 Context 中獲取路由參數(shù)。

easyswoole/http 2.x 之前版本綁定的參數(shù)將由框架內(nèi)部進行組裝到框架的 Query Param 數(shù)據(jù)之中,調(diào)用方式如下:

<?php
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        // /user/1
        $routeCollector->get('/user/{id:\d+}', function (Request $request, Response $response) {
            $id = $request->getQueryParam('id'); // 1
            $response->write("id: {$id}");
            return false;
        });
    }
}

參數(shù)約束驗證

你可以在路由參數(shù)后面添加正則表達式來限制路由參數(shù)的格式:

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/user/{name:.+}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $name = $context['name'];
            $response->write("name: {$name}");
            return false;
        });
        $routeCollector->get('/user1/{name:[A-Za-z]+}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $name = $context['name'];
            $response->write("name: {$name}");
            return false;
        });

        // 將限制 `/users/` 后面的id參數(shù),只能是數(shù)字 `[0-9]`
        $routeCollector->get('/user/{id:\d+}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id'];
            $response->write("id: {$id}");
            return false;
        });
        $routeCollector->get('/user1/{id:[0-9]+}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id'];
            $response->write("id: {$id}");
            return false;
        });

        $routeCollector->get('/user2/{id:[0-9]+}/{name:[a-z]+}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $id = $context['id'];
            $name = $context['name'];
            $response->write("id: {$id}, name: {$name}");
            return false;
        });
    }
}

路由參數(shù)中的斜杠字符

路由允許除 / 之外的所有字符出現(xiàn)在路由參數(shù)值中。 你必須使用正則表達式明確允許 / 成為占位符的一部分:

<?php
namespace App\HttpController;

use EasySwoole\Component\Context\ContextManager;
use EasySwoole\Http\AbstractInterface\AbstractRouter;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

class Router extends AbstractRouter
{
    function initialize(RouteCollector $routeCollector)
    {
        $routeCollector->get('/search/{search:.*}', function (Request $request, Response $response) {
            $context = ContextManager::getInstance()->get(Router::PARSE_PARAMS_CONTEXT_KEY);
            $search = $context['search'];
            $response->write("search: {$search}");
            return false;
        });
    }
}

路由分組

路由分組允許你共享 URI 前綴,而無需在每個單獨的路由上定義這些 URI` 前綴。

嵌套組嘗試智能地將 URI 前綴與其父組 “合并”。URI 前綴中的斜杠會在適當(dāng)?shù)牡胤阶詣犹砑印?/p>

<?php
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

$routeCollector->addGroup('/admin', function (RouteCollector $collector) {
    $collector->addRoute('GET', '/do-something', function (Request $request, Response $response) {
        $response->write('this is do-something');
        return false;
    });
    $collector->addRoute('GET', '/do-another-thing', function (Request $request, Response $response) {
        $response->write('this is do-another-thing');
        return false;
    });
    $collector->addRoute('GET', '/do-something-else', function (Request $request, Response $response) {
        $response->write('do-something-else');
        return false;
    });
});

// 和上述路由等價
$routeCollector->addRoute('GET', '/admin/do-something', function (Request $request, Response $response) {
    $response->write('this is do-something');
    return false;
});
$routeCollector->addRoute('GET', '/admin/do-another-thing', function (Request $request, Response $response) {
    $response->write('this is do-another-thing');
    return false;
});
$routeCollector->addRoute('GET', '/admin/do-something-else', function (Request $request, Response $response) {
     $response->write('do-something-else');
     return false;
});

特殊的路由

從路由調(diào)度到其他路由

如果要定一個調(diào)度到另一個 URI 的路由,可以使用 return 的方式,可快速實現(xiàn)類似重定向的功能,而不需要去定義完整的路由或者控制器:

$routeCollector->addRoute('GET', '/here', function (Request $request, Response $response) {
     return '/there';
});
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;
use FastRoute\RouteCollector;

$routeCollector->addGroup('/admin', function (RouteCollector $collector) {
    // /admin/test?version=1
    // /admin/test?version=2
    // /admin/test?version=3
    $collector->addRoute('GET', '/test', function (Request $request, Response $response) {
        $version = $request->getQueryParam('version');

        if ($version == 1) {
            $path = '/V1' . $request->getUri()->getPath(); // "/V1/admin/test"
        } else {
            // /V2/admin/test
            $path = '/V2' . $request->getUri()->getPath(); // "/V2/admin/test"
        }

        // return "/V1/admin/test";
        // return "/V2/admin/test";
        return $path;
    });
});

// 注意:/admins/index?version=x 不能匹配到下面這個 action 路由配置參數(shù)
// 需要單獨配置路由,如下所示:即執(zhí)行對應(yīng)的 App\HttpController\V1\Admins.php 類的 index() 方法
// $routeCollector->addRoute('GET', '/admins/index', '/V1/Admin/index');
$routeCollector->addGroup('/admins', function (RouteCollector $collector) {
    // /admin/test?version=1
    // /admin/test?version=2
    // /admin/test?version=3
    $collector->addRoute('GET', '/{action}', function (Request $request, Response $response) {
        $version = $request->getQueryParam('version');

        if ($version == 1) {
            $path = '/V1' . $request->getUri()->getPath(); // "/V1/admins/test"
        } else {
            $path = '/V2' . $request->getUri()->getPath(); // "/V2/admins/test"
        }

        // return "/V1/admin/test";
        // return "/V2/admin/test";
        return $path;
    });
});

全局模式攔截

Router.php 加入以下代碼,即可開啟全局模式攔截

$this->setGlobalMode(true);

全局模式攔截下,路由將只匹配 Router.php 中指定的 $handler 的控制器方法進行響應(yīng),將不會執(zhí)行框架的默認(rèn)解析。

異常錯誤處理

通過以下 2 個方法,可設(shè)置 路由HTTP請求方法無法匹配 以及 路由無法匹配 的處理機制:

Router.php 加入以下代碼:

<?php
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;

// 路由HTTP請求方法無法匹配
$this->setMethodNotAllowCallBack(function (Request $request, Response $response) {
    $response->withStatus(404);
    return false; // 結(jié)束此次響應(yīng)
});

// 路由未知,無法匹配
$this->setRouterNotFoundCallBack(function (Request $request, Response $response){
    $response->withStatus(404);
    return 'index'; // 重定向到 index 路由
});

該回調(diào)函數(shù)只針對于 fastRoute 未匹配狀況,如果回調(diào)里面不結(jié)束該請求響應(yīng),則該次請求將會繼續(xù)進行 Dispatch 并嘗試尋找對應(yīng)的控制器進行響應(yīng)處理。

主站蜘蛛池模板: 麻豆精品视频在线观看 | 免费黄色软件网站 | 亚洲免费在线视频观看 | 国产成a人亚洲精v品在线观看 | 日本不卡一区二区三区四区 | 四虎综合网 | 玖玖操 | 国产91在线播放9色不卡 | 欧美日韩成人精品 | 日产欧产美韩系列在线播放 | 国产精品乱码一区二三区小蝌蚪 | 中文字幕国产在线观看 | 国产91桃色在线观看网站 | 国产视频网站在线观看 | 成人毛片av | 亚洲电影免费看 | 国产精品成人免费一区久久羞羞 | 亚洲成网 | 亚洲精品美女视频 | 成人性生交大全免费中文版 | 成人av男人的天堂 | 欧美永久免费 | 一区二区三区无码高清视频 | 久久亚洲成人 | 欧美午夜精品久久久久免费视 | 国产一区中文字幕 | 久久久久久久久久免费 | 欧美成在线视频 | 亚洲一区二区精品3399 | 性生活视频免费 | 精品欧美一二三区 | 国产h视频在线观看 | 97日日夜夜 | 国产精品一区二区久久精品爱微奶 | 欧美国产中文 | 国产欧美三区 | av三级毛片 | 高清国产一区二区三区四区五区 | 国产精品国产三级国快看 | 亚洲第一成人在线 | 国内外一级毛片 |