1
如題目所述,在VendorController
postLogin
方法dd(Auth::user())
得到的值爲null,但$attempt
得到結果true
,我無法獲得已經嘗試的數據。Laravel 5.3獲得嘗試true但Auth :: User返回null?
我routes/web.php
Route::group(['prefix' => 'vendor','as' => 'Vendor.'], function() {
Route::get('login', '[email protected]')->name('Login');
Route::post('login', '[email protected]')->name('Post.Login');
});
我VendorController
:
public function postLogin(Request $request)
{
$attempt = Auth::guard('vendor')->attempt([
'acctId' => $request->acctId,
'password' => $request->password
]);
if($attempt){
dd(Auth::user());
}
}
我Vendor
型號
namespace ACME\Entities;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Contracts\Auth\Authenticatable;
use Illuminate\Auth\Authenticatable as AuthenticableTrait;
class Vendor extends Model implements Authenticatable
{
use AuthenticableTrait;
protected $table = 'vendor';
protected $primaryKey = 'id';
public $timestamps = true;
protected $fillable = [
'acctId',
'password',
'active',
'remark'
];
protected $guarded = ['password'];
}
我config/auth.php
return [
'defaults' => [
// 'guard' => 'web',
// 'passwords' => 'users',
'guard' => 'user',
'passwords' => 'users',
],
'guards' => [
// 'web' => [
// 'driver' => 'session',
// 'provider' => 'users',
// ],
'api' => [
'driver' => 'token',
'provider' => 'users',
],
'user' => [
'driver' => 'session',
'provider' => 'users',
],
'admin' => [
'driver' => 'session',
'provider' => 'admins',
],
'vendor' => [
'driver' => 'session',
'provider' => 'vendors',
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => ACME\Entities\User::class,
],
'admins' => [
'driver' => 'eloquent',
'model' => ACME\Entities\Admin::class,
],
'vendors' => [
'driver' => 'eloquent',
'model' => ACME\Entities\Vendor::class,
],
],
'passwords' => [
'users' => [
'provider' => 'users',
'email' => 'auth.emails.password',
'table' => 'user',
'expire' => 60,
],
'admins' => [
'provider' => 'admins',
'email' => 'auth.emails.password',
'table' => 'admin',
'expire' => 60,
],
'vendors' => [
'provider' => 'vendors',
'email' => 'auth.emails.password',
'table' => 'vendor',
'expire' => 60,
],
],
];
當使用非默認警衛使用Laravel multi-auth時,這非常重要。似乎奇怪的是,它會允許警衛特定的身份驗證,但實際上並沒有在登錄後將用戶設置爲身份驗證實例(這可能是一個很好的理由,超出我目前的理解水平)。 花了我一會兒才找到這個。謝謝! – bfuzze