文章目录
安装dingo
运行命令
composer require dingo/api
使用一下命令发布API的配置文件到config文件下:
php artisan vendor:publish --provider="Dingo\Api\Provider\LaravelServiceProvider"
运行成功后会在config文件下生成api.php
配置.env
API_STANDARDS_TREE=vnd (x表示本地私有环境 prs没有商业发布的项目 vnd公开发布的项目)
API_SUBTYPE=myapp (项目短名称)
API_PREFIX=api (项目前缀)
API_VERSION=v1 (版本)
API_DEBUG=true (是否开启调试模式)
使用案例
$api = app('Dingo\Api\Routing\Router');
$api->version('v1', function($api) {
$api->group(['name' => 'api.','namespace' => 'App\Http\Controllers',], function ($api) {
$api->post('/wechat/index','WechatController@index');
});
});
一、处理422错误
在app/providers/AppServiceProvider下boot方法中加入如下代码:
// 将所有的 Exception 全部交给 App\Exceptions\Handler 来处理
app('api.exception')->register(function (\Exception $exception) {
$request = \Illuminate\Http\Request::capture();
return app('App\Exceptions\Handler')->render($request, $exception);
});
在app/Exceptions/Handler中重写convertValidationExceptionToResponse具体代码如下:
use Illuminate\Validation\ValidationException;
use Dingo\Api\Routing\Helpers;
在class中 use Helpers;
public function convertValidationExceptionToResponse(ValidationException $e, $request)
{
$data = $e->validator->getMessageBag();
$msg = collect($data)->first();
if (is_array($msg)) {
$msg = $msg[0];
}
$arr['code'] = 422;
$arr['message'] = $msg;
return $this->response->array($arr);
}