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

控制器

功能介紹

毫無(wú)疑問(wèn),控制器層是負(fù)責(zé)處理客戶(hù)端請(qǐng)求,轉(zhuǎn)發(fā)給響應(yīng)模型,并將結(jié)果返回給客戶(hù)端。EasySwoole 使用了對(duì)象池復(fù)用模式,降低對(duì)象創(chuàng)建、銷(xiāo)毀的開(kāi)銷(xiāo),注入 requestresponse 對(duì)象來(lái)完成客戶(hù)端與服務(wù)端之間的交互。

示例

App/HttpController/ 目錄下增加文件 User.php

代碼

<?php
/**
 * @CreateTime:   2020/8/19 12:30 上午
 * @Author:       huizhang  <2788828128@qq.com>
 * @Copyright:    copyright(2020) Easyswoole all rights reserved
 * @Description:  用戶(hù)控制器
 */
namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\Controller;

class User extends Controller
{

    /**
     * 用戶(hù)信息
     *
     * @return string
     * CreateTime: 2020/8/19 12:37 上午
     */
    public function userInfo()
    {
        // 獲取 get 參數(shù)
        $name = $this->request()->getQueryParam('name');

        // 輸出到終端
        var_dump($name);

        // 返回給客戶(hù)端
        $this->response()->write($name . PHP_EOL);

        // return 返回的值會(huì)讓框架在此進(jìn)行控制器方法調(diào)度,將繼續(xù)執(zhí)行 User 控制器類(lèi)的 requestTotal 方法 
        return '/User/requestTotal';
    }

    /**
     * 接口請(qǐng)求量
     *
     * CreateTime: 2020/8/19 12:37 上午
     */
    public function requestTotal()
    {
        $this->response()->write('請(qǐng)求數(shù)+1' . PHP_EOL);

        // 還可以 return,但不要兩個(gè)方法互相調(diào)用,會(huì)導(dǎo)致死循環(huán)
    }

    /**
     * 此控制器拋異常時(shí)會(huì)執(zhí)行此方法
     *
     * @param \Throwable $throwable
     * @throws \Throwable
     * CreateTime: 2020/8/19 12:48 上午
     */
    public function onException(\Throwable $throwable): void
    {
        parent::onException($throwable); // TODO: Change the autogenerated stub
    }

    /**
     * gc 方法將在執(zhí)行完 afterAction 方法之后自動(dòng)調(diào)用,可自行覆蓋實(shí)現(xiàn)其他的 gc 回收邏輯
     *
     * CreateTime: 2020/8/19 12:52 上午
     */
    public function gc()
    {
        parent::gc(); // TODO: Change the autogenerated stub
    }

    /**
     * 當(dāng)控制器方法執(zhí)行結(jié)束之后將調(diào)用該方法,可自行覆蓋該方法實(shí)現(xiàn)數(shù)據(jù)回收等邏輯
     *
     * @param string|null $actionName
     * CreateTime: 2020/8/19 12:51 上午
     */
    public function afterAction(?string $actionName): void
    {
        parent::afterAction($actionName); // TODO: Change the autogenerated stub
    }

    /**
     * 當(dāng)請(qǐng)求方法未找到時(shí),自動(dòng)調(diào)用該方法,可自行覆蓋該方法實(shí)現(xiàn)自己的邏輯
     *
     * @param string|null $action
     * CreateTime: 2020/8/19 12:51 上午
     */
    public function actionNotFound(?string $action)
    {
        parent::actionNotFound($action); // TODO: Change the autogenerated stub
    }

    /**
     * 所有控制器請(qǐng)求都會(huì)先經(jīng)過(guò)該方法,如果此方法返回 false 則請(qǐng)求不繼續(xù)往下執(zhí)行,可用于權(quán)限驗(yàn)證
     *
     * @param string|null $action
     * @return bool|null
     * CreateTime: 2020/8/19 12:52 上午
     */
    public function onRequest(?string $action): ?bool
    {
        return parent::onRequest($action); // TODO: Change the autogenerated stub
    }

}

執(zhí)行過(guò)程

啟動(dòng) easyswoole

php easyswoole.php server start

訪(fǎng)問(wèn)

curl http://localhost:9501/user/userInfo?name=easyswoole

執(zhí)行結(jié)果

服務(wù)端輸出

?  doc-new git:(master) ? php easyswoole.php server start
#!/usr/bin/env php
  ______                          _____                              _
 |  ____|                        / ____|                            | |
 | |__      __ _   ___   _   _  | (___   __      __   ___     ___   | |   ___
 |  __|    / _` | / __| | | | |  \___ \  \ \ /\ / /  / _ \   / _ \  | |  / _ \
 | |____  | (_| | \__ \ | |_| |  ____) |  \ V  V /  | (_) | | (_) | | | |  __/
 |______|  \__,_| |___/  \__, | |_____/    \_/\_/    \___/   \___/  |_|  \___|
                          __/ |
                         |___/

main server                   SWOOLE_WEB
listen address                0.0.0.0
listen port                   9501
worker_num                    8
reload_async                  true
max_wait_time                 3
document_root                 /Users/guoyuzhao/sites/doc-new/Static
enable_static_handler         true
pid_file                      /Users/guoyuzhao/sites/doc-new/Temp/pid.pid
log_file                      /Users/guoyuzhao/sites/doc-new/Log/swoole.log
user                          guoyuzhao
swoole version                4.5.2
php version                   7.4.8
easyswoole version            3.4.0-dev
run mode                      dev
temp dir                      /Users/guoyuzhao/sites/doc-new/Temp
log dir                       /Users/guoyuzhao/sites/doc-new/Log
string(10) "easyswoole"

客戶(hù)端輸出

?  ssh curl http://localhost:9501/user/userInfo\?name\=easyswoole

easyswoole
請(qǐng)求數(shù)+1

控制器方法

easyswoole 在控制器基類(lèi)中實(shí)現(xiàn)了幾個(gè)通用方法,當(dāng)然用戶(hù)也可根據(jù)需要進(jìn)行方法重寫(xiě)實(shí)現(xiàn)自己的邏輯

onRequest

所有控制器請(qǐng)求都會(huì)先經(jīng)過(guò)該方法,如果此方法返回 false 則請(qǐng)求不繼續(xù)往下執(zhí)行,可用于權(quán)限驗(yàn)證

protected function onRequest(?string $action): ?bool
{
    return true;
}

onException

當(dāng)執(zhí)行控制器方法拋異常時(shí)會(huì)調(diào)用該方法,可自行覆蓋該方法實(shí)現(xiàn)異常捕獲等邏輯

protected function onException(\Throwable $throwable): void
{
    throw $throwable;
}

afterAction

當(dāng) action 執(zhí)行結(jié)束后調(diào)用該方法,可自行覆蓋該方法實(shí)現(xiàn)數(shù)據(jù)回收等邏輯

protected function afterAction(?string $actionName): void
{

}

actionNotFound

當(dāng)請(qǐng)求方法未找到時(shí),自動(dòng)調(diào)用此方法

protected function actionNotFound(?string $action)
{
    $class = static::class;
    $this->writeJson(\EasySwoole\Http\Message\Status::CODE_NOT_FOUND,null,"{$class} has not action for {$action}");
}

gc

gc 方法在 afterAction 方法執(zhí)行完后調(diào)用

protected function gc()
{
    //恢復(fù)默認(rèn)值
    foreach ($this->defaultProperties as $property => $value) {
        $this->{$property} = $value;
    }
}

注意事項(xiàng)

  • 只有第一次請(qǐng)求時(shí)才會(huì)調(diào)用構(gòu)造函數(shù)
  • 對(duì)象池模式只重置非靜態(tài) public 屬性
  • 對(duì)象池復(fù)用模式只針對(duì)單一進(jìn)程,多個(gè) worker 進(jìn)程不共享
  • 文件夾、文件、類(lèi)名為大駝峰,變量與類(lèi)方法小駝峰(規(guī)范)
  • action 返回的字符串將會(huì)被 url 解析規(guī)則以及 route 路由規(guī)則解析
  • 兩個(gè) actionreturn 不能互相調(diào)用,否則將導(dǎo)致死循環(huán)

另外注意:在控制器類(lèi)的方法(onRequest/action 等方法)中創(chuàng)建子協(xié)程,在子協(xié)程中使用 $this 的相關(guān)屬性值時(shí)必須使用 use 引入,不使用 use 引入時(shí)將導(dǎo)致協(xié)程上下文數(shù)據(jù)錯(cuò)亂。

錯(cuò)誤使用示例:

下面以在 Index 控制器類(lèi)中的 action(index) 中使用為示例:

<?php
/**
 * This file is part of EasySwoole.
 *
 * @link http://m.jrrswxmm.cn
 * @document http://m.jrrswxmm.cn
 * @contact http://m.jrrswxmm.cn/Preface/contact.html
 * @license https://github.com/easy-swoole/easyswoole/blob/3.x/LICENSE
 */

namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\Utility\Random;

class Index extends Controller
{
    public function index()
    {
        // 設(shè)置請(qǐng)求標(biāo)識(shí)
        $requestFlag = Random::number(3);
        $this->request()->withAttribute('requestFlag', $requestFlag);
        $rq = '第 ' . $this->request()->getRequestParam('times') . ' 次請(qǐng)求:';
        var_dump($rq . $this->request()->getAttribute('requestFlag'));
        go(function () {
            $rq = '第 ' . $this->request()->getRequestParam('times') . ' 次請(qǐng)求:';
            go(function () {
                $rq = '第 ' . $this->request()->getRequestParam('times') . ' 次請(qǐng)求:';
                \co::sleep(2);
                var_dump($rq . $this->request()->getAttribute('requestFlag'));
            });
            \co::sleep(4);
            // 【這里的數(shù)據(jù)會(huì)錯(cuò)亂】
            var_dump($rq . $this->request()->getAttribute('requestFlag'));
        });
        $this->response()->write('this is index!' . $this->request()->getRequestParam('times'));
    }
}

然后我們?cè)L問(wèn) http://127.0.0.1:9501/?times=1(示例請(qǐng)求地址),隔 1s 后我們?cè)俅卧L(fǎng)問(wèn) http://127.0.0.1:9501/?times=2(示例請(qǐng)求地址),發(fā)現(xiàn)出現(xiàn)如下運(yùn)行結(jié)果,控制臺(tái)輸出結(jié)果:

string(21) "第 1 次請(qǐng)求:765"
string(21) "第 1 次請(qǐng)求:765"
string(21) "第 2 次請(qǐng)求:823"
string(21) "第 1 次請(qǐng)求:823"
string(21) "第 2 次請(qǐng)求:823"
string(21) "第 2 次請(qǐng)求:823"

發(fā)現(xiàn)和我們想象中的完全不一樣,第 1 次請(qǐng)求掛載的數(shù)據(jù)被“污染”了,因?yàn)?EasySwoole 控制器采用的是對(duì)象池模式。

正確使用方式如下:

<?php
/**
 * This file is part of EasySwoole.
 *
 * @link http://m.jrrswxmm.cn
 * @document http://m.jrrswxmm.cn
 * @contact http://m.jrrswxmm.cn/Preface/contact.html
 * @license https://github.com/easy-swoole/easyswoole/blob/3.x/LICENSE
 */

namespace App\HttpController;

use EasySwoole\Http\AbstractInterface\Controller;
use EasySwoole\Utility\Random;

class Index extends Controller
{
    public function index()
    {
        // 設(shè)置請(qǐng)求標(biāo)識(shí)
        $requestFlag = Random::number(3);
        $this->request()->withAttribute('requestFlag', $requestFlag);
        $rq = '第 ' . $this->request()->getRequestParam('times') . ' 次請(qǐng)求:';
        var_dump($rq . $this->request()->getAttribute('requestFlag'));
        go(function () use ($rq, $requestFlag) {
            go(function () use ($rq, $requestFlag) {
                \co::sleep(2);
                var_dump($rq . $requestFlag);
            });
            \co::sleep(4);
            // 【這里的數(shù)據(jù)會(huì)錯(cuò)亂】
            var_dump($rq . $requestFlag);
        });
        $this->response()->write('this is index!' . $this->request()->getRequestParam('times'));
    }
}

然后我們?cè)L問(wèn) http://127.0.0.1:9501/?times=1(示例請(qǐng)求地址),隔 1s 后我們?cè)俅卧L(fǎng)問(wèn) http://127.0.0.1:9501/?times=2(示例請(qǐng)求地址),發(fā)現(xiàn)出現(xiàn)如下運(yùn)行結(jié)果,控制臺(tái)輸出結(jié)果:

string(21) "第 1 次請(qǐng)求:690"
string(21) "第 1 次請(qǐng)求:690"
string(21) "第 2 次請(qǐng)求:820"
string(21) "第 1 次請(qǐng)求:690"
string(21) "第 2 次請(qǐng)求:820"
string(21) "第 2 次請(qǐng)求:820"

發(fā)現(xiàn)數(shù)據(jù)正常了。

主站蜘蛛池模板: 午夜视频免费 | 久久精品二区 | 国产黄色大片免费在线观看 | 成人精品鲁一区一区二区 | av黄色在线播放 | 国产亚洲精品女人久久久久久 | 在线观看欧美日韩 | 免费观看黄视频 | 青青草原亚洲 | 在线永久免费观看日韩a | 精品国产乱码久久久久夜 | 国产精品视频 | 日本精品久久 | 日韩手机在线观看 | 中文在线一区二区 | 欧美成人激情 | 午夜剧| 欧美视频在线一区 | 精品国产区 | 亚洲欧美视频在线观看 | 免费一区二区 | 欧美一区二区三区视频在线观看 | 色综合视频在线观看 | 四虎影视在线播放 | 亚洲欧美第一页 | 在线a电影| 国外爱爱视频 | 成人片在线播放 | 国产精品成人3p一区二区三区 | 国产成人综合一区二区三区 | 国产精品久久久久久久久久久久冷 | 91观看| 97国产一区二区精品久久呦 | 色精品| 黄色片免费在线 | 国产精品一区二区三区四区五区 | 在线视频 中文字幕 | 毛片在线视频 | 亚洲三级网站 | 国产精品免费久久久久影视 | 日韩成人一级片 |