安装mixphp时用到的php模块,MixPHP 开发 API 接口简单实例

MixPHP 是一款基于 Swoole 的常驻内存型 PHP 高性能框架,框架的高性能特点非常适合开发 API 接口,而且 MixPHP 非常接近传统 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 文件。

squares.svg

第二步

修改应用配置文件:

修改 Response 组件默认输出格式为 JSON 格式。

修改 404/500 错误输出格式为 JSON 格式。

squares.svg

框架默认的 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

namespace appsindexcontrollers;

use mixfacadesRequest;

use mixhttpController;

use appsindexmessagesErrorCode;

use appsindexmodelsArticlesForm;

class ArticlesController extends Controller

{

public function actionDetails()

{

// 使用模型

$model = new ArticlesForm();

$model->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

namespace appsindexmessages;

class ErrorCode

{

const SUCCESS = 0;

const INVALID_PARAM = 100001;

const ERROR_ID_UNFOUND = 200001;

}

创建表单验证模型:

apps/index/models/ArticlesForm.php

namespace appsindexmodels;

use mixvalidatorsValidator;

use appscommonmodelsArticlesModel;

class ArticlesForm extends Validator

{

public $id;

// 规则

public function rules()

{

return [

'id' => ['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.php

namespace appscommonmodels;

use mixfacadesRDB;

class ArticlesModel

{

const TABLE = 'articles';

// 获取一行数据通过id

public function getRowById($id)

{

$sql = "SELECT * FROM `" . self::TABLE . "` WHERE id = :id";

$row = RDB::createCommand($sql)->bindParams([

'id' => $id,

])->queryOne();

return $row;

}

}

以上就是全部代码的编写。

第四步

使用 Postman 测试,如下:

squares.svg

接口开发与测试完成,是不是很简单呀。

MixPHP

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值