如何基于 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', 'Notadd\Foundation\Setting\Controllers\SettingController@all');$this->router->post('set', 'Notadd\Foundation\Setting\Controllers\SettingController@set');
});

Notadd 针对需要跨域的 API 还提供了 cross 的路由中间件,以实现 API 跨域的功能。

例如,为前两个 API 提供跨域的功能实现,代码参考如下:

$this->router->group(['middleware' => ['auth:api', 'cross', 'web'], 'prefix' => 'api/setting'], function () {$this->router->post('all', 'Notadd\Foundation\Setting\Controllers\SettingController@all');$this->router->post('set', 'Notadd\Foundation\Setting\Controllers\SettingController@set');
});

控制器

由于有了独立的 API处理器 ,控制器层可以制作简单处理,仅需向控制器注入 handler,并由 handler 提供的辅助方法返回 API 数据给前台,即可。

例如,在前面路由调用的 SettingController 中,仅需要注入 AllHandler ,使用方法 toResponse 和 generateHttpResponse 来返回结果给前台,代码参考如下:

<?php
/*** This file is part of Notadd.** @author TwilRoad <269044570@qq.com>* @copyright (c) 2016, iBenchu.org* @datetime 2016-11-08 17:01*/
namespace Notadd\Foundation\Setting\Controllers;use Notadd\Foundation\Routing\Abstracts\Controller;
use Notadd\Foundation\Setting\Contracts\SettingsRepository;
use Notadd\Foundation\Setting\Handlers\AllHandler;
use Notadd\Foundation\Setting\Handlers\SetHandler;/*** Class SettingController.*/
class SettingController extends Controller
{/*** @var \Notadd\Foundation\Setting\Contracts\SettingsRepository*/protected $settings;/*** SettingController constructor.** @param \Notadd\Foundation\Setting\Contracts\SettingsRepository $settings** @throws \Illuminate\Contracts\Container\BindingResolutionException*/public function __construct(SettingsRepository $settings){parent::__construct();$this->settings = $settings;}/*** All handler.** @param \Notadd\Foundation\Setting\Handlers\AllHandler $handler** @return \Notadd\Foundation\Passport\Responses\ApiResponse* @throws \Exception*/public function all(AllHandler $handler){return $handler->toResponse()->generateHttpResponse();}/*** Set handler.** @param \Notadd\Foundation\Setting\Handlers\SetHandler $handler** @return \Notadd\Foundation\Passport\Responses\ApiResponse* @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 的代码如下:

<?php
/*** This file is part of Notadd.** @author TwilRoad <269044570@qq.com>* @copyright (c) 2016, iBenchu.org* @datetime 2016-11-23 14:44*/
namespace Notadd\Foundation\Setting\Handlers;use Illuminate\Container\Container;
use Notadd\Foundation\Passport\Abstracts\DataHandler;
use Notadd\Foundation\Setting\Contracts\SettingsRepository;/*** Class AllHandler.*/
class AllHandler extends DataHandler
{/*** @var \Notadd\Foundation\Setting\Contracts\SettingsRepository*/protected $settings;/*** AllHandler constructor.** @param \Illuminate\Container\Container                         $container* @param \Notadd\Foundation\Setting\Contracts\SettingsRepository $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 的代码如下:

<?php
/*** This file is part of Notadd.** @author TwilRoad <269044570@qq.com>* @copyright (c) 2016, iBenchu.org* @datetime 2016-11-23 15:09*/
namespace Notadd\Foundation\Setting\Handlers;use Illuminate\Container\Container;
use Notadd\Foundation\Passport\Abstracts\SetHandler as AbstractSetHandler;
use Notadd\Foundation\Setting\Contracts\SettingsRepository;/*** Class SetHandler.*/
class SetHandler extends AbstractSetHandler
{/*** @var \Notadd\Foundation\Setting\Contracts\SettingsRepository*/protected $settings;/*** SetHandler constructor.** @param \Illuminate\Container\Container                         $container* @param \Notadd\Foundation\Setting\Contracts\SettingsRepository $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 开发完成。

如何基于 Notadd 构建 API (Laravel 写 API)相关推荐

  1. laravel android api,Laravel RESTful API与Android应用程序

    我正在使用Laravel 5 Framework开发一个Android应用程序和一个RESTful API. 我在登录活动时遇到了麻烦:流程是用户要求输入第8个字符的代码,并且服务器网络向他发送了一条 ...

  2. rest laravel_如何通过测试驱动开发来构建Laravel REST API

    rest laravel by Kofo Okesola 由Kofo Okesola 如何通过测试驱动开发来构建Laravel REST API (How to build a Laravel RES ...

  3. 基于 Node.js + Koa 构建完整的 Web API (配置 ESLint 和使用 Airbnb 编码规范)

    主题内容:基于 Node.js + Koa 构建完整的 Web API (配置 ESLint 和使用 Airbnb 代码规范) 背景描述:上一篇 基于 Node.js + Koa 构建完整的 Web ...

  4. 基于 Go 语言构建企业级的 RESTful API 服务

    现代软件架构已经逐渐从单体架构转向微服务架构,在微服务架构中服务间通信采用轻量级通信机制.对于轻量级通信的协议而言,通常基于 HTTP 和 RPC ,能让服务间的通信变的标准化并且无状态化.此外开发模 ...

  5. 使用 TDD 测试驱动开发来构建 Laravel REST API

    TDD 以及敏捷开发的先驱者之一的 James Grenning有句名言: 如果你没有进行测试驱动开发,那么你应该正在做开发后堵漏的事 - James Grenning 今天我们将进行一场基于 Lar ...

  6. 用laravel写一个API

    目的 用Laravel写一个API,查询所有的用户信息,示例如下 最起码要跑起来 [{"id": 1,"name": "Sinmu",&qu ...

  7. 使用 TDD 测试驱动开发来构建 Laravel REST API 1

    TDD 以及敏捷开发的先驱者之一的 James Grenning有句名言: 如果你没有进行测试驱动开发,那么你应该正在做开发后堵漏的事 - James Grenning 今天我们将进行一场基于 Lar ...

  8. 如何基于已有的 REST API 实现 GraphQL API

    这是「进击的Coder」的第 356 篇技术分享 作者:Tyler Hawkins 译者:samyu2000 校对者:PassionPenguin, k8scat 来源:掘金开发者社区 " ...

  9. 亿级流量架构演进实战 | 从零构建亿级流量API网关 01

    这不是一个讲概念的专栏,而且我也不擅长讲概念,每一篇文章都是一个故事,我希望你可以通过这些故事了解我当时在实际工作中遇到问题和背后的思考,架构设计是种经验,我有幸参与到多个亿级系统的架构设计中,有所收 ...

最新文章

  1. 块级作用域(es5没闭包-有闭包-let对比)
  2. LibJson数据解析方法
  3. 怎么计算python程序执行时间_【华为云技术分享】计算python程序执行时间
  4. pythonclass全局变量_python怎么使用全局变量
  5. 使用gtest进行自己的单独测试的代码介绍
  6. java类初始化顺序_《To Be a Better Javaer》-- Java 基础篇 vol.2:面向对象
  7. 02、Windows Phone 套接字(Socket)实战之服务器端设计
  8. 太实用了!Schedule模块, Python 周期任务神器!
  9. ES3、ES5、ES6、ES2016、ES2017、ES2018、ES2019
  10. 什么是pisa测试_PISA测试是什么?
  11. 对大数据量Excel文件自动排版、转换成PDF用于印刷出版
  12. ubuntu redis desktop manager 编译问题解决
  13. lr背景虚化_LR调色教程,用LR把夏天的颜色以图片的样式呈现出来
  14. js判断网络链接的四种方法
  15. Vue2.x - Vue Router
  16. 3D相册 效果图如下
  17. 搜狐邮箱无法被Foxmail、网易邮箱大师代收的问题的解决方法
  18. QQ群视频出现imsdk登录失败的解决方法
  19. Python之第十章 调试
  20. 强大的U盘启动盘制作工具Rufus

热门文章

  1. 三、“涤纶纤维和棉纤维两组分纤维在涤/棉混纺织物燃烧过程中有着明显的物理相互作用和化学相互作用”,解释这两种作用。
  2. Java——方法重载(overload)(比较两个数据是否相等)
  3. C/C++之string类小结
  4. linux C语言 文件相关知识01
  5. [Linux]消息队列
  6. Linux的SOCKET编程 简单演示
  7. 如何掌握java API的方法
  8. web开发课程,CSS标准文档流与脱离文档流,已整理成文档
  9. 大牛用SSM框架实现了支付宝的支付功能,满满干货指导
  10. 百度、华为、京东、B站最新面试题汇集,实战篇