为什么自定义守卫在页面 reload/redirect 上被注销?
Why does custom guard get logged out on page reload/redirect?
我创建了一个新的守卫来登录自定义类型的用户。我可以使用 Auth::attempt('webguest')
登录用户,但登录不会在页面重新加载后持续存在。它仅在我使用 web
-guard 时有效。例如,参见我的两条测试路线:
Route::get('test1', function () {
\Auth::guard('webguest')->attempt([
'id' => 5,
'password' => 2222
]);
// here dump(\Auth::guard('webguest')->check()) shows true
return \Redirect::to('/test2');
});
Route::get('test2', function () {
return \Auth::guard('webguest')->check() ? "guest account logged in" : "guest not logged in";
// dumps not logged in
});
我的海关守卫:
config/auth.php
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'webguest' => [
'driver' => 'session',
'provider' => 'guests'
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\Models\User::class,
],
'guests' => [
'driver' => 'eloquent',
'model' => App\Models\Guest::class
],
]
Guest 和 User 模型都扩展了 Illuminate\Foundation\Auth\User as Authenticatable
。
我怎样才能像 web
守卫一样使用自定义守卫登录?
我找到了根本原因。
在我的 Guest 模型中,用于登录的“用户名”是 id,模型中有一个覆盖方法:
public function getAuthIdentifier() {
return $this->user->getKey();
}
我删除了它并添加了以下内容:
public function getAuthIdentifierName()
{
return 'id';
}
现在自定义守卫就像一个魅力。
我创建了一个新的守卫来登录自定义类型的用户。我可以使用 Auth::attempt('webguest')
登录用户,但登录不会在页面重新加载后持续存在。它仅在我使用 web
-guard 时有效。例如,参见我的两条测试路线:
Route::get('test1', function () {
\Auth::guard('webguest')->attempt([
'id' => 5,
'password' => 2222
]);
// here dump(\Auth::guard('webguest')->check()) shows true
return \Redirect::to('/test2');
});
Route::get('test2', function () {
return \Auth::guard('webguest')->check() ? "guest account logged in" : "guest not logged in";
// dumps not logged in
});
我的海关守卫:
config/auth.php
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'webguest' => [
'driver' => 'session',
'provider' => 'guests'
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\Models\User::class,
],
'guests' => [
'driver' => 'eloquent',
'model' => App\Models\Guest::class
],
]
Guest 和 User 模型都扩展了 Illuminate\Foundation\Auth\User as Authenticatable
。
我怎样才能像 web
守卫一样使用自定义守卫登录?
我找到了根本原因。 在我的 Guest 模型中,用于登录的“用户名”是 id,模型中有一个覆盖方法:
public function getAuthIdentifier() {
return $this->user->getKey();
}
我删除了它并添加了以下内容:
public function getAuthIdentifierName()
{
return 'id';
}
现在自定义守卫就像一个魅力。