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

安裝

composer require easyswoole/http-annotation=3.x

組件要求

  • php: >=8.1
  • ext-json: *
  • psr/http-message: ^1.0
  • easyswoole/http: 3.x
  • ext-mbstring: *
  • ext-dom: *
  • ext-simplexml: *
  • ext-libxml: *
  • easyswoole/parsedown: ^1.0

注意:用戶在使用 EasySwoole 注解控制器 進行 EasySwoole 項目開發時,仍需要 use 注解相對應的命名空間。這顯然不是一個高效的做法。我們推薦在 PhpStorm 環境下進行開發,并且在 PhpStorm 中安裝 Jetbrain 自帶的 PHP Annotation 組件,可以提供注解命名空間自動補全、注解屬性代碼提醒、注解類跳轉等非常有幫助的。(PhpStorm 2019 以上版本的 IDE,該組件可能不能正常使用。)

組件優勢

在使用 EasySwoole Http 注解控制器組件進行開發時,可以很方便地生成 API 接口文檔,可以極大地提高了我們 phper 的開發效率。具體如何使用請看 自動注解文檔 章節。

IDE 提示

當代碼中使用注解與 EasySwoole 提供的 Param 沖突,無法實現 IDE 提示,可以使用別名的方式去使用 EasySwooleParam 注解,代碼如下。

<?php
namespace App\HttpController;

use EasySwoole\HttpAnnotation\AnnotationController;
use EasySwoole\HttpAnnotation\Attributes\Param as ReqParam;
use EasySwoole\HttpAnnotation\Enum\ParamFrom;
use EasySwoole\HttpAnnotation\Validator\Required;

class Index extends AnnotationController
{
    #[ReqParam(
        name: "deviceId",
        from: ParamFrom::JSON,
        validate: [
            new Required("deviceId is required.")
        ]
    )]
    function reportAction()
    {

    }
}

實現原理

注解控制器,完整命名空間為 EasySwoole\HttpAnnotation\AnnotationController,是繼承自 use EasySwoole\Http\AbstractInterface\Controller的子類。它重寫了父類的__hook方法,從而實現對注解控制器的支持。

__hook

__hook 方法中,自動解析使用在當前控制器類上的注解。 該方法是承接 Dispatcher 與控制器實體邏輯的橋梁。在該方法中,注解控制器做了以下事情:

  • 檢查當前請求的 http 請求方法是否在當前控制器類的 action 允許的請求方法范圍內,來實現過濾非法請求的目的(前提:使用了 Api 注解的 allowMethod 屬性限制)。
  • 讀取在控制器類的 action 中使用的 Api 注解信息,讀取在控制器類的 (非靜態非只讀的 publicprotected 修飾的) 成員變量中使用的 Context/Di/Inject 注解信息并自動給成員變量賦值。
  • 檢查并執行成員變量注解邏輯
  • 檢查 onRequest 函數注解參數并執行注解參數邏輯校驗
  • 檢查使用在 action 上的注解標簽并進行參數校驗與邏輯校驗

基礎示例

<?php
namespace App\HttpController;

use EasySwoole\EasySwoole\Trigger;
use EasySwoole\HttpAnnotation\AnnotationController;
use EasySwoole\HttpAnnotation\Attributes\Param;
use EasySwoole\HttpAnnotation\Exception\ValidateFail;
use EasySwoole\HttpAnnotation\Validator\Required;

class Index extends AnnotationController
{
    #[Param(
        name: "name",
        validate: [
            new Required("")
        ]
    )]
    #[Param(
        name: "age",
        validate: [
            new Required("")
        ]
    )]
    public function index()
    {
        $data = $this->request()->getRequestParam();
        $this->response()->write("your name is {$data['name']} and age {$data['age']}");
    }

    public function onException(\Throwable $throwable): void
    {
        if ($throwable instanceof ValidateFail) {
            $this->response()->withHeader('Content-type', 'text/html;charset=utf-8');
            $this->response()->write("字段【{$throwable->getFailRule()->currentCheckParam()->name}】校驗錯誤");
        } else {
            Trigger::getInstance()->throwable($throwable);
        }
    }
}

在以上代碼中,會自動對 nameage 字段進行校驗,當校驗失敗時,拋出一個異常,校驗成功則進入 index action 邏輯。具體請看成員屬性注解章節。

主站蜘蛛池模板: 奇米影视四色777me | 欧洲成人在线观看 | 四虎中文字幕 | 久久久精品国产 | 国产精品美女久久久久久免费 | 亚洲综合99 | 精品国产欧美一区二区 | 另类 综合 日韩 欧美 亚洲 | 国产视频久久久久久久 | 久久99国产精品久久99大师 | 亚洲精品视频在线播放 | 成年人黄色一级片 | 亚洲欧美在线观看 | 黄色国产 | 亚洲成人精品一区二区三区 | 亚洲综合大片69999 | 久久精品视 | 成人久久久精品国产乱码一区二区 | 国产精品久久久久一区二区三区 | 天天躁日日躁狠狠躁av麻豆 | 狠狠操中文字幕 | 一级黄色大片 | 日韩视频免费 | 欧美另类亚洲 | 天天夜碰日日摸日日澡 | 国产精品视频一区二区免费不卡 | 欧美亚洲视频 | 在线免费黄色小视频 | 2021最新热播中文字幕-第1页-看片视频 青青青久草 | 久久99精品国产99久久6尤 | www.五月天婷婷 | 久久成人国产 | 啵啵影院午夜男人免费视频 | 91免费在线视频 | 欧美日韩国产精品一区二区 | 夸克满天星在线观看 | 免费xxxxx在线观看网站软件 | 欧美日韩综合精品 | 2019中文字幕在线观看 | 九九九视频精品 | 成人黄色一级网站 |