在Laravel 5.7的中间件中,Auth::check()始终为false

在Laravel 5.7的中间件中,Auth::check()始终为false,laravel,laravel-5,Laravel,Laravel 5,我已经在许多Laravel应用程序中使用了中间件,但这是一个我以前从未遇到过的愚蠢情况。对于Auth::check() 这是用户模块的路由 <?php Route::group(['middleware' => 'web', 'namespace' => 'Modules\User\Http\Controllers'], function () { Route::get('/', 'UserController@index'); Route::get('logi

我已经在许多Laravel应用程序中使用了中间件,但这是一个我以前从未遇到过的愚蠢情况。对于
Auth::check()

这是
用户
模块的
路由

<?php
Route::group(['middleware' => 'web', 'namespace' => 'Modules\User\Http\Controllers'], function () {
    Route::get('/', 'UserController@index');
    Route::get('login', 'LoginController@showLoginForm')->name('login');
    Route::post('login', 'LoginController@login');
    Route::post('logout', 'LoginController@logout')->name('logout');
});
Route::group(['middleware' => 'admin', 'prefix' => 'user', 'namespace' => 'Modules\User\Http\Controllers'], function () {
    Route::get('register', 'RegisterController@showRegistrationForm')->name('register');
    Route::post('register', 'RegisterController@register');
});
<?php

namespace Modules\User\Http\Middleware;

use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class AdminMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle(Request $request, Closure $next)
    {
        $log = Auth::check();
        dd($log);
        return $next($request);
    }
}
这是
kernel.php

protected $routeMiddleware = [
    'auth' => \App\Http\Middleware\Authenticate::class,
    'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
    'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
    'can' => \Illuminate\Auth\Middleware\Authorize::class,
    'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
    'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
    'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
    'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
    'admin' => \Modules\User\Http\Middleware\AdminMiddleware::class
];
protected $middlewarePriority = [
    \Illuminate\Session\Middleware\StartSession::class,
    \Illuminate\View\Middleware\ShareErrorsFromSession::class,

     \Modules\User\Http\Middleware\AdminMiddleware::class

    \App\Http\Middleware\Authenticate::class,
    \Illuminate\Routing\Middleware\ThrottleRequests::class,
    \Illuminate\Session\Middleware\AuthenticateSession::class,
    \Illuminate\Routing\Middleware\SubstituteBindings::class,
    \Illuminate\Auth\Middleware\Authorize::class,
    \App\Http\Middleware\CheckProfileRequiredData::class, // putting CheckProfileRequiredData after Auth priority is required! to perform it's check after auth middleware
    \App\Http\Middleware\CheckUserMustPayWithoutAnsweringDietRequiredQuestions::class,
];

但是,
dd($log)
的结果总是错误的。这里怎么了

您还需要将
web
中间件添加到用户模块路由组。
因为会话从那里开始。

请附加您的中间件地址:

\Modules\User\Http\Middleware\AdminMiddleware::class


您可以将中间件的优先级设置为在
StartSession
之后加载,以确保它将在会话启动后加载

kernel.php中

protected $routeMiddleware = [
    'auth' => \App\Http\Middleware\Authenticate::class,
    'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
    'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
    'can' => \Illuminate\Auth\Middleware\Authorize::class,
    'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
    'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
    'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
    'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
    'admin' => \Modules\User\Http\Middleware\AdminMiddleware::class
];
protected $middlewarePriority = [
    \Illuminate\Session\Middleware\StartSession::class,
    \Illuminate\View\Middleware\ShareErrorsFromSession::class,

     \Modules\User\Http\Middleware\AdminMiddleware::class

    \App\Http\Middleware\Authenticate::class,
    \Illuminate\Routing\Middleware\ThrottleRequests::class,
    \Illuminate\Session\Middleware\AuthenticateSession::class,
    \Illuminate\Routing\Middleware\SubstituteBindings::class,
    \Illuminate\Auth\Middleware\Authorize::class,
    \App\Http\Middleware\CheckProfileRequiredData::class, // putting CheckProfileRequiredData after Auth priority is required! to perform it's check after auth middleware
    \App\Http\Middleware\CheckUserMustPayWithoutAnsweringDietRequiredQuestions::class,
];

只是说,另一个解决方案是将其添加到全局中间件堆栈中,而不是web中间件组中!(仅将其添加到web,不能两者兼有)

我的最佳猜测是,因为您没有将
web
中间件附加到
admin
中间件,所以
auth
中间件没有运行,因此您没有经过身份验证。但这只是猜测,所以没有答案。你的身份验证配置是什么?如果是会话,请发布会话驱动程序和配置。基本上需要auth.php和session.php配置files@Namoshek我应该写这个<代码>路由::组(['middleware'=>['admin','web'],“prefix'=>“user',@Namoshek
web
中间件组由
RouteServiceProvider
自动应用于您的默认routes.php文件。因此无需添加
web
,那么您为什么要将其添加到另一组路由,根据您的描述,该组路由位于同一文件中?是否确实已添加?如果如果手动添加,请确保在
admin
之前调用
web
,即
Route::group(['middleware'=>['web','admin'],…)
您的意思是这样的
Route::group(['middleware'=>['admin','web'],'prefix'=>'user',
web
中间件组由
RouteServiceProvider
自动应用于默认routes.php文件。因此无需添加
web