Laravel 基本 HTTP 身份验证检查返回错误
Laravel Basic HTTP Auth Check Returning False
我正在使用 Laravel 中提供的基本 HTTP 身份验证来登录我的网站。但是,当我调用 Auth::Check()
时,即使我已登录,我总是得到 false 作为响应。
Auth::Check()
是否不适用于基本身份验证模型?如果不行,是否有任何方法可以检查基本身份验证以查看用户是否已登录?
这是我的用户 class:
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();
#.......
}
我的路线:
在 5.2 版本中改变了。
如果您将使用会话、csrf、cookie ext。你应该在你的路由中使用这样的 "web" 中间件:
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',
],
];
我正在使用 Laravel 中提供的基本 HTTP 身份验证来登录我的网站。但是,当我调用 Auth::Check()
时,即使我已登录,我总是得到 false 作为响应。
Auth::Check()
是否不适用于基本身份验证模型?如果不行,是否有任何方法可以检查基本身份验证以查看用户是否已登录?
这是我的用户 class:
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();
#.......
}
我的路线:
在 5.2 版本中改变了。
如果您将使用会话、csrf、cookie ext。你应该在你的路由中使用这样的 "web" 中间件:
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',
],
];