中文在线一区二区_欧美在线综合_久久久久久综合_欧美一区二区三区视频_国产免费看_国产福利精品一区

請求攔截

EasySwoole 的控制器并沒有提供類似中間件的說法,而是提供了控制器中的 onRequest 事件進行驗證。

例如,我們需要對 /api/user/* 下的路徑進行 cookie 驗證。那么有以下兩種方案:

全局 Request 及 Response 事件

全局 Initialize 事件 中注冊.

public static function initialize()
{
    date_default_timezone_set('Asia/Shanghai');

    // onRequest v3.4.x+
    \EasySwoole\Component\Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_ON_REQUEST, function (\EasySwoole\Http\Request $request, \EasySwoole\Http\Response $response) {
        $cookie = $request->getCookieParams('user_cookie');
        // 對 cookie 進行判斷,比如在數據庫或者是 redis 緩存中,存在該 cookie 信息,說明用戶登錄成功
        $isLogin = true;
        if ($isLogin) {
            // 返回 true 表示繼續往下執行控制器 action
            return true;
        } else {
            // 這一步可以給前端響應數據,告知前端未登錄
            $data = Array(
                "code" => 200,
                "result" => null,
                "msg" => '請先登錄'
            );
            $response->withHeader('Content-Type', 'application/json;charset=utf-8');
            $response->withStatus(200);
            $response->write(json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES));
            // 返回 false 表示不繼續往下執行控制器 action
            return false;
        }
    });

    // afterRequest v3.4.x+
    \EasySwoole\Component\Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_AFTER_REQUEST, function (\EasySwoole\Http\Request $request, \EasySwoole\Http\Response $response) {

    });
}

EasySwoole 3.4.x 版本之前:可在項目根目錄的 EasySwooleEvent.php 中看到 onRequestafterRequest 方法。

定義 Base 控制器

<?php

namespace App\HttpController\Api\User;

use EasySwoole\Http\AbstractInterface\Controller;

abstract class Base extends Controller
{
    protected function onRequest(?string $action): ?bool
    {
        $cookie = $this->request()->getCookieParams('user_cookie');
        // 對 cookie 進行判斷,比如在數據庫或者是 redis 緩存中,存在該 cookie 信息,說明用戶登錄成功
        $isLogin = true;
        if ($isLogin) {
            // 返回 true 表示繼續往下執行控制器 action
            return true;
        } else {
            // 這一步可以給前端響應數據,告知前端未登錄
            $this->writeJson(401, null, '請先登錄');
            // 返回 false 表示不繼續往下執行控制器 action
            return false;
        }
    }
}

后續,只要 /api/user/* 路徑下的控制器,都繼承自 Base 控制器,都可以自動實現對 cookie 攔截了

行為權限校驗也是如此,可以判斷某個用戶是否對該控制器的 action 或者請求路徑有沒有權限

主站蜘蛛池模板: 艹久久| 黄色精品网站 | 午夜久久久久 | 久久国产亚洲精品 | 欧美日视频 | 国产亚洲精品美女久久久久久久久久 | 久久综合狠狠综合久久综合88 | 成人在线免费观看小视频 | 国产av毛片| 狠久久 | 久久99这里只有精品 | 波多野结衣中文字幕一区二区三区 | 一级二级在线观看 | 成人av观看 | 一区二区日韩 | 成人免费毛片高清视频 | 91免费视频网站 | 亚洲国产精品久久久久婷婷老年 | 狠狠的日 | 九九热1 | 精品一区二区久久久久久久网站 | 欧美成人精品一区二区 | 国产成人久久精品一区二区三区 | 精品超碰 | 国产精品女教师av久久 | 久久久久国产一区二区三区四区 | 日韩在线欧美 | 亚洲精品免费视频 | 国内精品久久久久久久影视简单 | 免费精品人在线二线三线区别 | 国产精品美女久久久久久久网站 | 亚洲欧美一区二区三区在线 | 国产中文字幕一区 | 国产色区 | 偷拍自拍第一页 | 欧美二区三区 | 99视频这里有精品 | 国产三级在线观看 | 视频三区 | 国产在线综合视频 | 亚洲欧美国产精品专区久久 |