在Laravel 5.7的中间件中,Auth::check()始终为false
我已经在许多Laravel应用程序中使用了中间件,但这是一个我以前从未遇到过的愚蠢情况。对于在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
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',@Namoshekweb
中间件组由RouteServiceProvider
自动应用于您的默认routes.php文件。因此无需添加web
,那么您为什么要将其添加到另一组路由,根据您的描述,该组路由位于同一文件中?是否确实已添加?如果如果手动添加,请确保在admin
之前调用web
,即Route::group(['middleware'=>['web','admin'],…)
您的意思是这样的Route::group(['middleware'=>['admin','web'],'prefix'=>'user',
?web
中间件组由RouteServiceProvider
自动应用于默认routes.php文件。因此无需添加web