标签:Yii 2

Yii2 自定义 RESTful API 返回格式

Yii 2 framework 提供了一套 REST API ,通过简单配置即可对外提供服务,支持 JSON、XML 多种格式选择输出;支持 HTTP Basic auth、OAuth 2 等认证方式,用起来确实很爽。

在定义 API 的时候,最常见的就是自定义返回格式,我找到 4 种方式,纪录如下:

第一种:来自官方文档,通过修改 config 文件

return [
    // ...
    'components' => [
        'response' => [
            'class' => 'yii\web\Response',
            'on beforeSend' => function ($event) {
                $response = $event->sender;
                if ($response->data !== null && Yii::$app->request->get('suppress_response_code')) {
                    $response->data = [
                        'success' => $response->isSuccessful,
                        'data' => $response->data,
                    ];
                    $response->statusCode = 200;
                }
            },
        ],
    ],
];

第二种:使用 controller 中的 afterAction 方法,在响应完 action 之后,对数据格式化

use Yii;
class MobileController extends yii\rest\Controller
{
    public function afterAction($action, $result)
    {
        $rs = parent::afterAction($action, $result);
        // 也可以再定义 response
        // $response = Yii::$app->response;
        // $response->statusCode = 200;
        // $response->data = ['message' => 'hello world'];
        return ['data' => $rs, 'error' => '0'];
    }
}

第三种:自定义 Error handler ,来自 github

public function init()
{
    parent::init();

    $handler = new \app\components\ApiErrorHandler;
    \Yii::$app->set('errorHandler', $handler);
    $handler->register();
}

第四种:与第一种类似,在 controller 中绑定 response 的 beforeSend 事件,不同是它不是 global ,更灵活

public function init()
{
    parent::init();

    Event::on(Response::className(), Response::EVENT_BEFORE_SEND, [$this, 'formatDataBeforeSend']);
}

public function formatDataBeforeSend($event)
{
    $response = $event->sender;
    // do something
}

That’s all.
Fin.