国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

如何基于 Notadd 構建 API (Laravel 寫 API)

megatron / 1303人閱讀

摘要:例如,為前兩個提供跨域的功能實現,代碼參考如下控制器由于有了獨立的處理器,控制器層可以制作簡單處理,僅需向控制器注入,并由提供的輔助方法返回數據給前臺,即可。

如何基于 Notadd 構建 API

Notadd 底層實現了 passport 機制,有統一的授權管理,主要支持兩種方式進行 API 授權,一個是 client,領一個是 passport,這個在其他文檔中有做詳細的說明。

這里主要說的是,如何基于 Notadd 進行 API 接口的開發。

業務邏輯

熟悉 Laravel 的同學都應該知道,Laravel 遵循這樣的業務邏輯實現:

路由(route) -> 控制器(controller) -> 業務邏輯(model) -> 數據輸出(view)

而 Notadd 的 API 業務邏輯實現同樣遵循類似的流程:

路由(route) -> 控制器(controller) -> API 處理器(handler) -> 模型(model) -> 數據輸出(json)

其中,主要的差異在于,API 處理器提供了對數據輸出格式的輸出,返回的數據格式統一為:

[
    "code" => 200,             // API 接口返回的狀態碼,默認為 200
    "data" => [],              // API 接口返回的數據,主要為數組形式
    "message" => "success!",  // API 接口返回的提示信息,可以包含錯誤信息或成功信息
]
路由

Notadd 在實現 API 授權的時候,使用的是有 路由中間件(middleware) 的方式來實現的。

具體實現方式,是在路由的中間配置參數中添加 auth:api

例如,在實現 api/setting/all 和 api/setting/set 兩個 API 的時候,添加 auth:api 的中間件,代碼參考如下:

$this->router->group(["middleware" => ["auth:api", "web"], "prefix" => "api/setting"], function () {
    $this->router->post("all", "NotaddFoundationSettingControllersSettingController@all");
    $this->router->post("set", "NotaddFoundationSettingControllersSettingController@set");
});

Notadd 針對需要跨域的 API 還提供了 cross 的路由中間件,以實現 API 跨域的功能。

例如,為前兩個 API 提供跨域的功能實現,代碼參考如下:

$this->router->group(["middleware" => ["auth:api", "cross", "web"], "prefix" => "api/setting"], function () {
    $this->router->post("all", "NotaddFoundationSettingControllersSettingController@all");
    $this->router->post("set", "NotaddFoundationSettingControllersSettingController@set");
});
控制器

由于有了獨立的 API處理器 ,控制器層可以制作簡單處理,僅需向控制器注入 handler,并由 handler 提供的輔助方法返回 API 數據給前臺,即可。

例如,在前面路由調用的 SettingController 中,僅需要注入 AllHandler ,使用方法 toResponse 和 generateHttpResponse 來返回結果給前臺,代碼參考如下:


 * @copyright (c) 2016, iBenchu.org
 * @datetime 2016-11-08 17:01
 */
namespace NotaddFoundationSettingControllers;

use NotaddFoundationRoutingAbstractsController;
use NotaddFoundationSettingContractsSettingsRepository;
use NotaddFoundationSettingHandlersAllHandler;
use NotaddFoundationSettingHandlersSetHandler;

/**
 * Class SettingController.
 */
class SettingController extends Controller
{
    /**
     * @var NotaddFoundationSettingContractsSettingsRepository
     */
    protected $settings;

    /**
     * SettingController constructor.
     *
     * @param NotaddFoundationSettingContractsSettingsRepository $settings
     *
     * @throws IlluminateContractsContainerBindingResolutionException
     */
    public function __construct(SettingsRepository $settings)
    {
        parent::__construct();
        $this->settings = $settings;
    }

    /**
     * All handler.
     *
     * @param NotaddFoundationSettingHandlersAllHandler $handler
     *
     * @return NotaddFoundationPassportResponsesApiResponse
     * @throws Exception
     */
    public function all(AllHandler $handler)
    {
        return $handler->toResponse()->generateHttpResponse();
    }

    /**
     * Set handler.
     *
     * @param NotaddFoundationSettingHandlersSetHandler $handler
     *
     * @return NotaddFoundationPassportResponsesApiResponse
     * @throws Exception
     */
    public function set(SetHandler $handler)
    {
        return $handler->toResponse()->generateHttpResponse();
    }
}
API Handler 和模型

在 API Handler中提供了模型的操作接口。

在 Notadd 中,提供了兩類 API Handler,一類是 DataHandler,另一類是 SetHandler,顧名思義,DataHandler 僅提供數據返回接口,而 SetHandler 不僅提供數據返回接口,還提供其他操作處理的接口。

具體差異體現在,DataHandler 在返回數據接口時僅調用方法 data,而 SetHandler 在調用 data 方法前還有調用 execute 方法。

例如,在前面的 SettingController 中使用的 AllHandler 為 DataHandler 類 Handler,提供返回所有 配置項 的 API 功能,SetHandler 為 SetHandler 類 Handler,提供 修改配置項 并返回所有 配置項 的 API 功能。

AllHandler 的代碼如下:


 * @copyright (c) 2016, iBenchu.org
 * @datetime 2016-11-23 14:44
 */
namespace NotaddFoundationSettingHandlers;

use IlluminateContainerContainer;
use NotaddFoundationPassportAbstractsDataHandler;
use NotaddFoundationSettingContractsSettingsRepository;

/**
 * Class AllHandler.
 */
class AllHandler extends DataHandler
{
    /**
     * @var NotaddFoundationSettingContractsSettingsRepository
     */
    protected $settings;

    /**
     * AllHandler constructor.
     *
     * @param IlluminateContainerContainer                         $container
     * @param NotaddFoundationSettingContractsSettingsRepository $settings
     */
    public function __construct(
        Container $container,
        SettingsRepository $settings
    ) {
        parent::__construct($container);
        $this->settings = $settings;
    }

    /**
     * Http code.
     *
     * @return int
     */
    public function code()                                                 // 定義 API 操作結果的狀態碼
    {
        return 200;
    }

    /**
     * Data for handler.
     *
     * @return array
     */
    public function data()                                                  // 定義 API 返回的數據
    {
        return $this->settings->all()->toArray();
    }

    /**
     * Errors for handler.
     *
     * @return array
     */
    public function errors()                                                // 定義 API 操作失敗時返回的信息
    {
        return [
            "獲取全局設置失敗!",
        ];
    }

    /**
     * Messages for handler.
     *
     * @return array
     */
    public function messages()                                             // 定義 API 操作成功時返回的信息
    {
        return [
            "獲取全局設置成功!",
        ];
    }
}

SetHandler 的代碼如下:


 * @copyright (c) 2016, iBenchu.org
 * @datetime 2016-11-23 15:09
 */
namespace NotaddFoundationSettingHandlers;

use IlluminateContainerContainer;
use NotaddFoundationPassportAbstractsSetHandler as AbstractSetHandler;
use NotaddFoundationSettingContractsSettingsRepository;

/**
 * Class SetHandler.
 */
class SetHandler extends AbstractSetHandler
{
    /**
     * @var NotaddFoundationSettingContractsSettingsRepository
     */
    protected $settings;

    /**
     * SetHandler constructor.
     *
     * @param IlluminateContainerContainer                         $container
     * @param NotaddFoundationSettingContractsSettingsRepository $settings
     */
    public function __construct(
        Container $container,
        SettingsRepository $settings
    ) {
        parent::__construct($container);
        $this->settings = $settings;
    }

    /**
     * Data for handler.
     *
     * @return array
     */
    public function data()                                                                    // 定義 API 返回的數據
    {
        return $this->settings->all()->toArray();
    }

    /**
     * Errors for handler.
     *
     * @return array
     */
    public function errors()                                                                  // 定義 API 操作失敗時返回的信息
    {
        return [
            "修改設置失敗!",
        ];
    }

    /**
     * Execute Handler.
     *
     * @return bool
     */
    public function execute()                                                                 // 定義 API 執行的修改操作
    {
        $this->settings->set("site.enabled", $this->request->input("enabled"));
        $this->settings->set("site.name", $this->request->input("name"));
        $this->settings->set("site.domain", $this->request->input("domain"));
        $this->settings->set("site.beian", $this->request->input("beian"));
        $this->settings->set("site.company", $this->request->input("company"));
        $this->settings->set("site.copyright", $this->request->input("copyright"));
        $this->settings->set("site.statistics", $this->request->input("statistics"));

        return true;
    }

    /**
     * Messages for handler.
     *
     * @return array
     */
    public function messages()                                                                // 定義 API 操作成功時返回的信息
    {
        return [
            "修改設置成功!",
        ];
    }
}
數據輸出

API 結果的數據輸出,已經在 控制器(controller) 中做了處理。

至此,一個完整的 API 開發完成。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/22972.html

相關文章

  • 造個輪子,基于 Laravel5.4 的下一代 PHP 開發框架 (API/SPA/Vue2/iVi

    摘要:像操作系統一樣,你可以通過安裝軟件,成為適用于你的電腦。先進的技術方案,使得你無需擔心后期功能拓展與迭代問題,大大降低了維護成本。對于一個超過三年生命周期的項目來說,最適合不過。總之,是新的技術方向標,能讓每個藝術家像構建工程一樣構建程序。 這是我們團隊的一個非盈利項目,以Apache2.0協議開源...不限制商用 Notadd是什么 Notadd 是基于Laravel 和 Vue 的...

    Rocture 評論0 收藏0
  • 基于 Laravel 的模塊化開發框架 Notadd RC1 fix1 發布

    摘要:目前默認使用了包,所以無需拓展。簡單的消息隊列隊列為不同的后臺隊列服務提供統一的,例如,,,甚至其他基于關系型數據庫的隊列。隊列的目的是將耗時的任務延時處理,比如發送郵件,從而大幅度縮短請求和相應的時間。 更新內容 修復長時間沒訪問后登錄后臺空白的BUG (@1459416736) 修復部分后臺 server error 問題 (@1459416736) 增加 win 下 exten...

    Ryan_Li 評論0 收藏0
  • 基于 Laravel 的模塊化開發框架 Notadd RC1 發布

    摘要:目前默認使用了包,所以無需拓展。簡單的消息隊列隊列為不同的后臺隊列服務提供統一的,例如,,,甚至其他基于關系型數據庫的隊列。隊列的目的是將耗時的任務延時處理,比如發送郵件,從而大幅度縮短請求和相應的時間。下載地址地址地址 更新內容 修復了首頁編輯模式下滾動的BUG (@Eleven) 修復了后臺菜單管理修改后不跳轉的BUG (@ganlanshu0211) 修復后臺 ESLint 的...

    eccozhou 評論0 收藏0
  • Notadd Beta2 fix1 發布 基于Laravel的下一代PHP開發框架

    摘要:先進的技術方案,使得你無需擔心后期功能拓展與迭代問題,大大降低了維護成本。對于一個超過三年生命周期的項目來說,最適合不過。 Notadd是什么 Notadd 是基于 Laravel 和 Vue 的開源 PHP 框架, 由于其本身的靈活性和先進的技術架構,使得你通過模塊(主功能)、插件(功能增強)、模板(前端樣式)像搭積木一樣組合成你想要的,能夠快速完成商城、CMS、微信、論壇的開發。 ...

    firim 評論0 收藏0
  • 基于 Laravel 的模塊化開發框架 Notad Beta5 fix2

    摘要:目前默認使用了包,所以無需拓展。簡單的消息隊列隊列為不同的后臺隊列服務提供統一的,例如,,,甚至其他基于關系型數據庫的隊列。隊列的目的是將耗時的任務延時處理,比如發送郵件,從而大幅度縮短請求和相應的時間。 更新 添加單元測試代碼 添加功能測試代碼 重構 JWT 驗證機制 修正安裝時對數據庫及Redis連接、賬號和密碼的驗證 擴展 MIME 類型,使返回的文件頭信息正常 優化后臺導航欄...

    whidy 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<