我正在使用Laravel 5.4创建API,并且一切正常。我已经使用了以下中间件=> auth:api
Route::group(['middleware' => 'auth:api'], function(){
Route::get('URIValue', ControllerName@action) //Example
});
我已经用邮递员对其进行了测试,当请求标头包含以下键和值时,它可以很好地工作:
当api_token无效时,将执行Handler类的未经身份验证的函数。laravel返回的默认响应是
'error' => 'Unauthenticated' // in JSON format
但是,如果未设置Accept标头,则laravel默认返回一个视图。但是使用API时,视图是不可接受的。
如何强制laravel为路由组中的每个路由请求检查Accept报头是否设置了正确的值(在这种情况下,该值必须为=> accept / json)?
就像是:
protected function mapApiRoutes()
{
Route::prefix('api')
->middleware('api')
->namespace($this->namespace)
->header('Accept' => 'application/json') //this
->group(base_path('routes/api.php'));
}
要么
Route::group(['middleware' => 'auth:api',
'headers' => ['Accept' => 'application/json']
], function(){
Route::get('URIValue', ControllerName@action) //Example
});
您可以为此创建一个中间件。
您将检查并强制执行Accept标头,以便Laravel无论如何都将输出json。
class WeWantJson
{
/**
* We only accept json
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
$acceptHeader = $request->header('Accept');
if ($acceptHeader != 'application/json') {
return response()->json([], 400);
}
return $next($request);
}
}
并且在您中,App\Http\Kernel
您可以将中间件添加到您的api组中。然后,无需手动将其添加到路由/路由组中。
编辑:
您还可以添加一个中间件来强制执行json,无论如何...
class EnforceJson
{
/**
* Enforce json
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
$request->headers->set('Accept', 'application/json');
return $next($request);
}
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句