摘要:例如,为前两个提供跨域的功能实现,代码参考如下控制器由于有了独立的处理器,控制器层可以制作简单处理,仅需向控制器注入,并由提供的辅助方法返回数据给前台,即可。
如何基于 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 开发完成。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/22972.html
摘要:像操作系统一样,你可以通过安装软件,成为适用于你的电脑。先进的技术方案,使得你无需担心后期功能拓展与迭代问题,大大降低了维护成本。对于一个超过三年生命周期的项目来说,最适合不过。总之,是新的技术方向标,能让每个艺术家像构建工程一样构建程序。 这是我们团队的一个非盈利项目,以Apache2.0协议开源...不限制商用 Notadd是什么 Notadd 是基于Laravel 和 Vue 的...
摘要:目前默认使用了包,所以无需拓展。简单的消息队列队列为不同的后台队列服务提供统一的,例如,,,甚至其他基于关系型数据库的队列。队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短请求和相应的时间。 更新内容 修复长时间没访问后登录后台空白的BUG (@1459416736) 修复部分后台 server error 问题 (@1459416736) 增加 win 下 exten...
摘要:目前默认使用了包,所以无需拓展。简单的消息队列队列为不同的后台队列服务提供统一的,例如,,,甚至其他基于关系型数据库的队列。队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短请求和相应的时间。下载地址地址地址 更新内容 修复了首页编辑模式下滚动的BUG (@Eleven) 修复了后台菜单管理修改后不跳转的BUG (@ganlanshu0211) 修复后台 ESLint 的...
摘要:先进的技术方案,使得你无需担心后期功能拓展与迭代问题,大大降低了维护成本。对于一个超过三年生命周期的项目来说,最适合不过。 Notadd是什么 Notadd 是基于 Laravel 和 Vue 的开源 PHP 框架, 由于其本身的灵活性和先进的技术架构,使得你通过模块(主功能)、插件(功能增强)、模板(前端样式)像搭积木一样组合成你想要的,能够快速完成商城、CMS、微信、论坛的开发。 ...
摘要:目前默认使用了包,所以无需拓展。简单的消息队列队列为不同的后台队列服务提供统一的,例如,,,甚至其他基于关系型数据库的队列。队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短请求和相应的时间。 更新 添加单元测试代码 添加功能测试代码 重构 JWT 验证机制 修正安装时对数据库及Redis连接、账号和密码的验证 扩展 MIME 类型,使返回的文件头信息正常 优化后台导航栏...
阅读 2814·2021-11-25 09:43
阅读 2434·2021-10-09 09:44
阅读 2779·2021-09-22 15:49
阅读 2520·2021-09-01 11:43
阅读 2522·2019-08-30 14:16
阅读 428·2019-08-29 17:24
阅读 3007·2019-08-29 14:00
阅读 1358·2019-08-29 13:05