easyswoole - 基于swoole扩展实现的一款高性能php框架

安裝

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

組件優(yōu)勢

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

IDE 提示

當代碼中使用注解與 EasySwoole 提供的 Param 沖突,無法實現(xiàn) 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()
    {

    }
}

實現(xiàn)原理

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

__hook

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

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

基礎示例

<?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 邏輯。具體請看成員屬性注解章節(jié)。

主站蜘蛛池模板: 随州市东正专用汽车有限公司| 育婴师_催乳师证_月嫂证怎么考_育婴师证报考需要什么条件-家政培训网 | 逍遥安卓模拟器_安卓模拟器电脑版_安卓手游模拟器哪个好用_逍遥手机模拟器官网 | 长春互联网运营值选星广传媒,长春短视频运营,长春新媒体运营,长春互联网运营,长春抖音运营,吉林视频号代运营,吉林快手代运营,短视频推广公司,公众号运营,微博运营,新媒体运营 | 临沂网站建设,临沂网站制作,临沂网络公司,临沂小程序开发,临沂网站设计,沂水网站建设,沂南网站建设,蒙阴网站建设,平邑网站建设,费县网站建设,兰陵网站建设,郯城网站建设,临沭网站建设,莒南网站建设,兰山网络公司 | 华帝衣柜定制_全屋家具定制_橱柜定制-华帝家居 | 华网,华网资讯,华网头条,华人网络家园| 天津止回阀-止回阀报价/哪家好-天津蝶阀/进口阀门/通风蝶阀批发-闸阀阀门/球阀生产厂家-天津凯维斯阀门制造 | 快速卷帘门-电动卷帘门-快速堆积门-快速门厂家-任丘市康速机电设备有限公司 | 压力变送器,差压变送器,液位变送器,温度变送器生产厂家价格-西安仕乐克仪表科技有限公司 | 胶球清洗-射水抽气器-磷酸盐加药装置-连云港振辉机械设备有限公司 | 涂料分散剂_水墨分散剂-厚洹化学水性色浆助剂厂家 | 昆山开曼流体系统科技有限公司 | 洗地机,洗地机价格,扫地机,工业吸尘器,手推式洗地机,驾驶式洗地机,北京洗地机【北京高美环保科技有限公司】 | 山东日兴新材料股份有限公司 | 上海协格机电科技股份有限公司-上海格力中央空调安装报价工程服务商 | 深圳起重机,龙门吊,天车起重工程,电动葫芦,液压升降货梯-深圳市德力起重机械有限公司 | 卷帘门,防火卷帘,快速门,硬质快速门,提升门,伸缩门,堆积门,车库门维修-烟台捷曼门业有限公司 | 长沙联合产权交易所有限公司| 型煤锅炉进煤机|型煤链条炉排 |重型板链除渣机 |丹东刮板输送机|丹东脱硫除尘器-铧洋机械 | 江南专汽公司首页-消防车厂家,水罐/泡沫消防车价格(热销品牌) | 注塑机螺杆_光学无卤耐磨耐腐蚀螺杆_合金材料_螺杆研磨抛光机_杰宇螺杆 | 长春互联网运营值选星广传媒,长春短视频运营,长春新媒体运营,长春互联网运营,长春抖音运营,吉林视频号代运营,吉林快手代运营,短视频推广公司,公众号运营,微博运营,新媒体运营 | 球场地板_运动场地面_体育设施器材_地坪漆工程_项目承接-大上实业(深圳)有限公司 | 激光清洗机_激光除锈机_激光焊接机 - 上海锡昊激光科技有限公司 激光切管机_等离子切管机_相贯线切管机厂家|服务为先-山东美峰智能设备有限公司 | 辉煌食品,辉煌罐头-山东辉煌食品有限公司 | 维启科技-创造科技的无限可能 | 上海维启信息技术有限公司 建筑仿真 BIM 虚拟现实 VR AR 顶岗实习 建筑智能模型 | 陕西西安升降机_导轨式升降货梯_电动固定剪叉式升降平台_甘肃兰州液压机械厂家 | 医用手摇病床,医用电动病床,康养手摇病床,康养电动病床-河北丁丁医疗器械有限公司 | 汽油发电机,柴油发电机,小型汽油发电机,小型柴油发电机,家用发电机生产厂家——上海东明动力设备有限公司 | 印刷公司,北京印刷厂,宣传画册手册印刷厂-和智印彩页设计 | 双螺杆挤压膨化设备_挤压熟化设备_烘干设备_油炸设备及喷涂调味设备-山东铭本机械科技公司 | 慢直播摄像头厂家,监控直播摄像机厂家,景区慢直播设备,rtmp推流直播摄像头,实时摄像头监控直播-监控慢直播厂家:专注监控慢直播系统解决方案 | 泥沙泵_脱硫泵_潜水泵_离心泵_渣浆泵厂家|诚信为先-泰安华泰泵业制造有限公司 | 浙江桥梁检测车出租_杭州桥检车出租_桥梁检测车出租_桥检车租赁_桥梁检测车租赁-广州众诚设备租赁有限公司 | 网络公关公司_舆情监测_危机公关_品牌公关_一夜红传媒 | 熊猫家装-装修公司,上海装修、室内设计、家装、别墅装修、办公室装修、全屋定制就上熊猫家装 | 塑胶模具定制,提供注塑加工服务,塑料模具制造厂_博腾纳公司 | 酒类灌装机厂家_贴标机_灌装生产线-青州市锦德包装机械有限公司 酒店设计_建筑设计_室内装修装饰-北极点酒店设计公司 | 膨胀节_波纹膨胀节_非金属膨胀节_波纹管补偿器_膨胀节厂家-江苏苏创管业科技有限公司 | 宁波公司注册_宁波注册公司_宁波代理记账_宁波做内账|安隆会计专业服务机构 |