我正在使用Sentinel对用户进行身份验证,并使用身份验证中间件。
中间件代码:
public function handle($request, Closure $next)
{
var_dump(Sentinel::guest()); // prints false
if (Sentinel::guest()) {
if ($request->ajax()) {
return response('Unauthorized.', 401);
} else {
return redirect()->guest('/login');
}
}
return $next($request);
}
控制器代码:
public function getAccount() {
var_dump(Sentinel::guest()); // prints true
return Sentinel::getUser();
}
routes.php文件
Route::group(['middleware' => ['auth']], function () {
Route::get('api/v1/temp/users/account', 'App\Http\Controllers\UsersController@getAccount');
}
然后,如果我浏览到api/v1/temp/users/account
,则中间件中的var_dump()打印为false,而控制器内的var_dump()打印为true,这似乎是无意义的。
出了什么问题?
答案 0 :(得分:1)
原来我使用的是原生外立面而不是Laravel外观Cartalyst\Sentinel\Laravel\Facades\Sentinel
。那已经解决了。