我使用Laravel提供的基本HTTP身份验证登录我的网站。但是,当我致电Auth::Check()
时,即使我已登录,我仍然会将 false 作为回复。
Auth::Check()
无法使用基本身份验证模型吗?如果没有,是否有办法检查基本身份验证以查看用户是否已登录?
这是我的用户类:
namespace App;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'email', 'password',
];
/**
* The attributes excluded from the model's JSON form.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
public function getRememberToken()
{
return $this->remember_token;
}
public function setRememberToken($value)
{
$this->remember_token = $value;
}
public function getRememberTokenName()
{
return 'remember_token';
}
}
这是我将身份验证过滤器设置为使用
的代码段$this->middleware('auth.basic', ['only' => ['create', 'store', 'edit', 'update', 'destroy']]);
这是我的Auth::Check()
电话(始终打印0):
public function show($id)
{
echo \Auth::check() ? '1' : '0';
die();
#.......
}
答案 0 :(得分:3)
它在5.2版本中发生了变化。
如果你将使用session,csrf,cookie ext。你应该在你的路线中使用这样的“网络”中间件:
Route::group(['middleware' => ['web']], function () {
//
});
你可以在你的项目中看到新的kernel.php文件是这样的:
/**
* The application's route middleware groups.
*
* @var array
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
],
'api' => [
'throttle:60,1',
],
];