五月天激情丁香,国产精品2019,国产成人精品亚洲2020,国产精品免费视频一区二区三区,开心久久婷婷综合中文字幕,天堂视频在线观看免费完整版

onRequest 事件(即收到請求事件)

使用場景及原理

EasySwoole 收到任何的 HTTP 請求時,均會執行該事件。可以使用該事件可以對 HTTP 請求全局攔截,包括對請求進行允許跨域等操作。

使用方式說明

框架對 onRequest 事件的實現在 3.4.x 及以后的版本 中做了新的改動,實現方式由原來舊版本在主服務創建事件(mainServerCreate 事件)中定義改變為在 initialize 事件 中使用 Di 方式注入。目前最新穩定版本框架(3.4.x),具體實現及使用方式 (在 EasySwooleEvent.php 中的 initialize 事件中注入) 如下:

<?php

namespace EasySwoole\EasySwoole;

use EasySwoole\EasySwoole\AbstractInterface\Event;
use EasySwoole\EasySwoole\Swoole\EventRegister;

class EasySwooleEvent implements Event
{
    public static function initialize()
    {
        date_default_timezone_set('Asia/Shanghai');

        // 實現 onRequest 事件
        \EasySwoole\Component\Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_ON_REQUEST, function (\EasySwoole\Http\Request $request, \EasySwoole\Http\Response $response): bool {
            ###### 對請求進行攔截 ######
            // 不建議在這攔截請求,可增加一個控制器基類進行攔截
            // 如果真要攔截,判斷之后 return false; 即可
            /*
            $code = $request->getRequestParam('code');
            if (0){ // empty($code)驗證失敗
                $data = array(
                    "code" => \EasySwoole\Http\Message\Status::CODE_BAD_REQUEST,
                    "result" => [],
                    "msg" => '驗證失敗'
                );
                $response->write(json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES));
                $response->withHeader('Content-type', 'application/json;charset=utf-8');
                $response->withStatus(\EasySwoole\Http\Message\Status::CODE_BAD_REQUEST);
                return false;
            }
            return true;
            */

            ###### 處理請求的跨域問題 ######
            $origin = $request->getHeaderLine('origin') ?: '*';
            $response->withHeader('Access-Control-Allow-Origin', $origin);
            $response->withHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
            $response->withHeader('Access-Control-Allow-Credentials', 'true');
            $response->withHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, token');
            if ($request->getMethod() === 'OPTIONS') {
                $response->withStatus(\EasySwoole\Http\Message\Status::CODE_OK);
                return false;
            }

            return true;
        });
    }

    public static function mainServerCreate(EventRegister $register)
    {

    }
}

舊版本(3.4.x 之前版本)框架的 onRequest 事件的實現如下所示:

<?php

namespace EasySwoole\EasySwoole;

use EasySwoole\EasySwoole\Swoole\EventRegister;
use EasySwoole\EasySwoole\AbstractInterface\Event;
use EasySwoole\Http\Request;
use EasySwoole\Http\Response;

class EasySwooleEvent implements Event
{
    public static function initialize()
    {
        // TODO: Implement initialize() method.
        date_default_timezone_set('Asia/Shanghai');
    }

    public static function mainServerCreate(EventRegister $register)
    {

    }

    // 注冊 onRequest 事件回調
    public static function onRequest(Request $request, Response $response): bool
    {
        ###### 對請求進行攔截 ######
        // 不建議在這攔截請求,可增加一個控制器基類進行攔截
        // 如果真要攔截,判斷之后 return false; 即可
        /*
        $code = $request->getRequestParam('code');
        if (0){ // empty($code)驗證失敗
            $data = array(
                "code" => \EasySwoole\Http\Message\Status::CODE_BAD_REQUEST,
                "result" => [],
                "msg" => '驗證失敗'
            );
            $response->write(json_encode($data, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES));
            $response->withHeader('Content-type', 'application/json;charset=utf-8');
            $response->withStatus(\EasySwoole\Http\Message\Status::CODE_BAD_REQUEST);
            return false;
        }
        return true;
        */

        ###### 處理請求的跨域問題 ######
        $origin = $request->getHeaderLine('origin') ?: '*';
        $response->withHeader('Access-Control-Allow-Origin', $origin);
        $response->withHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');
        $response->withHeader('Access-Control-Allow-Credentials', 'true');
        $response->withHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization, X-Requested-With, token');
        if ($request->getMethod() === 'OPTIONS') {
            $response->withStatus(\EasySwoole\Http\Message\Status::CODE_OK);
            return false;
        }
        return true;
    }
}

注意事項

若在該事件中,執行 $response->end(),則該次請求不會進入路由匹配階段。

主站蜘蛛池模板: 97se亚洲国产综合自在线 | 99精品久久99久久久久久 | 片免费观看网站视频 | 久久最新免费视频 | 亚洲伊人天堂 | gogogo高清在线观看视频 | 日韩婷婷 | 四虎影视最新网站在线播放 | 四虎影视国产精品亚洲精品hd | 国产清纯白嫩大学生正在播放 | 操三八男人的天堂 | 青草国产视频 | 国产成人精品一区二区免费 | 久久99国产精品久久99 | 色列里番不知火舞h本全彩无遮挡 | 国产精品福利在线观看 | 国产精品高清一区二区三区不卡 | 99热网| 黄视频免费在线看 | 韩国美女福利专区一区二区 | 亚洲精品第三页 | 久久精品看片 | 国产四虎| 欧美在线性爱视频 | 久久久久久久99视频 | 国产伦精品一区二区三区高清 | 国产九九精品视频 | 五月天黄色网 | 久久婷婷婷 | 九九精品国产兔费观看久久 | 美女羞羞视频网站 | 蜜臀视频在线 | 丁香狠狠 | 色婷婷久久综合中文网站 | 乱中年女人伦中文字幕久久 | 婷婷丁香综合网 | 国产高清视频在线免费观看 | gogogo高清在线观看 | 免费人成在线观看网站品爱网 | 激情五月五月婷婷 | 国产成人精品综合网站 |