摘要:注意这个是的范例是一款基于的常驻内存型高性能框架,框架的高性能特点非常适合开发接口,而且非常接近传统框架,所以开发接口时非常简单。下面做一个开发接口的简单实例从表,通过获取一篇文章。第四步使用测试,如下接口开发与测试完成,是不是很简单呀。
注意:这个是 MixPHP V1 的范例
MixPHP 是一款基于 Swoole 的常驻内存型 PHP 高性能框架,框架的高性能特点非常适合开发 API 接口,而且非常接近传统 MVC 框架,所以开发接口时非常简单。
下面做一个开发 API 接口的简单实例:
从 articles 表,通过 id 获取一篇文章。
访问该接口的 URL:
http://www.e.com/articles/details?id=1
数据库表结构如下:
CREATE TABLE `articles` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `title` varchar(255) NOT NULL, `content` varchar(255) NOT NULL, `dateline` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;第一步
修改数据库配置文件,MixPHP 的应用配置文件中,关于数据库的信息都引用了 common/config/database.php 文件。
第二步修改应用配置文件:
修改 Response 组件默认输出格式为 JSON 格式。
修改 404/500 错误输出格式为 JSON 格式。
框架默认的 404/500 响应是网页,而 API 服务需要响应 JSON 数据,通常其他传统 MVC 框架需要修改很多地方才可完成这个需求,MixPHP 本身就提供该种配置,只需修改一下配置即可。
MixPHP 的默认 HTTP 应用中有两个配置文件,分别为:
http_permanent.php : 部署在 mix-httpd 的常驻同步模式时使用。
http_compatible.php :部署在 Apache/PHP-FPM 时使用。
开发 API 时我们推荐在 Apache/PHP-FPM 下开发,上线再部署至 mix-httpd 即可,反正是无缝切换的。
现在我们修改 response 键名下的 defaultFormat 键为 mixhttpError::FORMAT_JSON,如下:
// 响应 "response" => [ // 类路径 "class" => "mixhttpcompatibleResponse", // 默认输出格式 "defaultFormat" => mixhttpResponse::FORMAT_JSON, // json "json" => [ // 类路径 "class" => "mixhttpJson", ], // jsonp "jsonp" => [ // 类路径 "class" => "mixhttpJsonp", // callback键名 "name" => "callback", ], // xml "xml" => [ // 类路径 "class" => "mixhttpXml", ], ],
然后修改 main_compatible.php 文件中 error 键名下的 format 键为 mixhttpError::FORMAT_JSON,如下:
// 错误 "error" => [ // 类路径 "class" => "mixhttpError", // 输出格式 "format" => mixhttpError::FORMAT_JSON, ],第三步
创建控制器:
apps/index/controllers/ArticlesController.php
attributes = Request::get(); $model->setScenario("actionDetails"); if (!$model->validate()) { return ["code" => ErrorCode::INVALID_PARAM]; } // 获取数据 $data = $model->getDetails(); if (!$data) { return ["code" => ErrorCode::ERROR_ID_UNFOUND]; } // 响应 return ["code" => ErrorCode::SUCCESS, "data" => $data]; } }
创建错误码类:
apps/index/messages/ErrorCode.php
创建表单验证模型:
apps/index/models/ArticlesForm.php["integer", "unsigned" => true, "maxLength" => 10], ]; } // 场景 public function scenarios() { return [ "actionDetails" => ["required" => ["id"]], ]; } // 获取详情 public function getDetails() { return (new ArticlesModel())->getRowById($this->id); } }创建数据表模型:
apps/common/models/ArticlesModel.phpbindParams([ "id" => $id, ])->queryOne(); return $row; } }以上就是全部代码的编写。
第四步使用 Postman 测试,如下:
接口开发与测试完成,是不是很简单呀。
MixPHPGitHub: https://github.com/mixstart/m...
官网:http://www.mixphp.cn/
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/28369.html
摘要:消费者开发本例我们使用的多进程开发工具来完成这个需求,通常使用常驻进程来处理队列的消费,所以我们使用的类型,模式。中进程负责执行邮件发送任务。此时终端将打印成功收到测试邮件官网 注意:这个是 MixPHP V1 的范例 邮件发送是很常见的需求,由于发送邮件的操作一般是比较耗时的,所以我们一般采用异步处理来提升用户体验,而异步通常我们使用消息队列来实现。 传统 MVC 框架由于缺少多进程...
摘要:如何使用优化高并发场景写库或者耗时计算在的接口中使用消息队列,把要入库的数据写入的类型中。高容错子进程异常奔溃时,主进程将重建子进程。高性能多进程运行,充分利用多个并行计算,性能强劲。 经常在群里听到一些朋友问:TP 的项目怎么迁移到 mixphp 来处理高并发,我通常都是回复需要重写,可是一个开发很久的 TP 项目,代码量巨大,又怎么可能会花大量时间成本来重写呢? 那么为何我们不尝试...
摘要:异步队列消费者开发只提供了模式下运行控制器方法,并未提供主进程多子进程的进程模型,并未提供多线程处理。多线程异步队列服务只需写好控制器方法,然后在配置文件中配置下路由命名空间进程线程数量,就可在模式中启动多进程多线程模型的异步队列处理程序。 最近业余时间一直在开发ExpressPHP的第二个版本 MixPHP,今天下班想起之前一个面试官的问题:你为什么还要再造一个轮子呢?仔细回想,第一...
摘要:框架最新源代码行数行,因此可以很容易的改造它,成为你们公司的专属框架。也不同于其他基于的微服务框架,只聚焦于微服务治理,定位于开发的更多领域,覆盖从初创到亿元级体量的技术诉求。的授权全靠用户自愿购买,详情 MixPHP是什么 MixPHP 是秉承 普及 PHP 常驻内存型解决方案,促进 PHP 往更后端发展 的理念而创造,采用 Swoole 扩展作为底层引擎,围绕常驻内存的方式而设计,...
摘要:写基于和开发的失踪儿童信息平台。团圆系统的全称应该是公安部儿童失踪信息紧急发布平台,在新浪微博上有一个官方的微博账号,通过这个微博账号发布儿童失踪信息。 这是我在sf上的第一篇文章。写基于swoole、Mixphp和CodeIgniter开发的失踪儿童信息平台。 在2017年的时候,关注到有一个团圆系统,它是公安部专门为了快速扩散失踪儿童消息的平台,但是网上并没有找到这个平台的地址。当...
阅读 1762·2023-04-26 02:14
阅读 3690·2021-11-23 09:51
阅读 1324·2021-10-13 09:39
阅读 3943·2021-09-24 10:36
阅读 2947·2021-09-22 15:55
阅读 3469·2019-08-30 12:57
阅读 1960·2019-08-29 15:30
阅读 1924·2019-08-29 13:19