黄p网站_在线看中文字幕_亚洲电影免费观看_成人激情视频_欧美成视频_中国av在线

afterRequest 事件(即請求方法結束后執行事件)

使用場景及原理

該事件是在請求方法結束后執行。可以在該事件中做 trace,對請求進行追蹤監視以及獲取此次的響應內容。

使用方式說明

框架對 afterRequest 事件的實現在 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');

        // 實現 afterRequest 事件
        \EasySwoole\Component\Di::getInstance()->set(\EasySwoole\EasySwoole\SysConst::HTTP_GLOBAL_AFTER_REQUEST, function (\EasySwoole\Http\Request $request, \EasySwoole\Http\Response $response): void {

            // 示例:獲取此次請求響應的內容
            TrackerManager::getInstance()->getTracker()->endPoint('request');
            $responseMsg = $response->getBody()->__toString();
            Logger::getInstance()->console('響應內容:' . $responseMsg);
            // 響應狀態碼:
            // var_dump($response->getStatusCode());

            // tracker 結束,結束之后,能看到中途設置的參數,調用棧的運行情況
            TrackerManager::getInstance()->closeTracker();
        });

    }

    public static function mainServerCreate(EventRegister $register)
    {

    }
}

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

<?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)
    {
        // TODO: Implement mainServerCreate() method.
    }

    public static function onRequest(Request $request, Response $response): bool
    {
        // TODO: Implement onRequest() method.
        return true;
    }

    // 注冊 afterRequest 事件回調
    public static function afterRequest(Request $request, Response $response): void
    {
        // TODO: Implement afterRequest() method.

        // 示例:獲取此次請求響應的內容
        TrackerManager::getInstance()->getTracker()->endPoint('request');
        $responseMsg = $response->getBody()->__toString();
        Logger::getInstance()->console('響應內容:' . $responseMsg);
        // 響應狀態碼:
        // var_dump($response->getStatusCode());

        // tracker 結束,結束之后,能看到中途設置的參數,調用棧的運行情況
        TrackerManager::getInstance()->closeTracker();
    }
}
主站蜘蛛池模板: 国产精品一区二区三区四区 | 一区二区中文字幕 | 久久成人国产精品 | 亚洲国产精品久久久 | 综合久久久久 | 欧美极品一区二区 | 精品久久一区二区三区 | 福利视频一区 | 久久免费看 | 激情综合久久 | 在线观看视频一区二区三区 | 亚洲伊人久久综合 | 亚洲精品一区二三区 | 激情五月婷婷在线 | 欧美日韩国产综合网 | 亚洲一区二区 | 美女视频黄又黄又免费 | 精品国产一区二区三区在线观看 | 国产一区二区三区免费看 | 日韩欧美一级精品久久 | 欧美国产精品久久久 | 欧美国产一区二区三区 | 超碰首页 | 日韩在线成人 | 久在线视频 | 九九色综合 | 一区二区三区视频在线免费观看 | 一级毛片观看 | 日韩在线不卡 | 精品久| 免费观看黄a一级视频 | 在线观看中文字幕 | 久久99热精品免费观看牛牛 | 亚洲第一视频网站 | 国产精品久久久久久久久小说 | 亚洲成人一区二区 | 国产夜夜夜| 成人免费视频网站在线看 | 在线激情av| 成人免费高清 | 国产伦精品一区二区三区四区视频 |