基于Laravel会话的auth:api中间件无法正常工作

时间:2016-11-15 21:02:10

标签: php laravel laravel-5.3

我尝试使用Laravel 5.3的Auth Scaffolding,包括api路线。我想为api后卫使用会话驱动程序,但显然这没有任何影响。在我使用有效用户登录应用程序后(我从/login/home)我尝试输入路径/api/user,但它始终将我重定向到/homeRedirectIfAuthenticated中间件会重定向用户。

以下是我尝试的内容以及测试应用程序的快速概述:

// In "app\Http\Middleware\RedirectIfAuthenticated.php"
if (Auth::guard($guard)->check()) {
    return redirect('/home');
}

$guard为null,浏览到/api/user时if为true。

// In "config\auth.php"
'api' => [
    'driver' => 'session', // changed from token to session
    'provider' => 'users',
],

我将api guard的驱动程序更改为session

// In "app\Http\Kernel.php"
'api' => [
    'throttle:60,1',
    'bindings',
    \App\Http\Middleware\EncryptCookies::class,
    \Illuminate\Session\Middleware\StartSession::class,
],

我添加了中间件以支持api中间件中的cookie

// In "routes\api.php"
Route::get('/user', function (Request $request) {
    return $request->user();
})->middleware('auth:api');

这是一个新的Laravel安装附带的示例。

// In "app\Providers\RouteServiceProvider.php"
Route::group([
    'middleware' => 'api',
    'namespace' => $this->namespace,
    'prefix' => 'api',
], function ($router) {
    require base_path('routes/api.php');
});

api中间件应用于api.php文件中定义的所有路由。

我希望能够在用户登录后不使用令牌等查询我的API。我用Laravel 5.2编写的应用程序基本上具有相同的路由,但只有web中间件组和{{1应用于它的中间件。在Laravel 5.3中,添加auth中间件会导致所描述的问题。

编辑:我的配置尝试了以下内容:

auth

这非常合适,但事实并非如此,尽管// In "routes\web.php" Route::get('/test', function (Request $request) { return "test"; })->middleware(['auth']); 内的webapi后卫完全相同。

auth.php

1 个答案:

答案 0 :(得分:3)

即使我已经登录,我也有同样的问题,即在访问我的API路由时被重定向到/ home。 尝试在Kernel.php中更改api中间件的顺序,并将“绑定”放在最后位置,以便首先执行自定义中间件。