我有以下路线:
Route::group(['prefix' => 'api/v1', 'middleware' => 'api'], function() { Route::resource('authenticate', 'AuthenticateController', ['only' => ['index']]); Route::post('authenticate', 'AuthenticateController@authenticate'); Route::resource('users', 'UserController'); });
在UserController
具有测试,以确保当用户经由提交POST
,它正确地验证输入.这应该在无效时返回422,但它实际上返回302.在Postman中,它引发CSRF令牌错误,表明web
正在应用中间件组,这不是我想要的行为.
我怎样才能防止这种情况发生?
在RouteServiceProvider.php
改变
$router->group([ 'namespace' => $this->namespace, 'middleware' => 'web', ], function ($router) { require app_path('Http/routes.php'); });
至:
$router->group([ 'namespace' => $this->namespace, ], function ($router) { require app_path('Http/routes.php'); });
然后使用Route::group(['middleware' => 'web'])
in 包装您的Web路由routes.php
.所以api路由不会受到web
中间件的影响.