Laravel 5.3 получить попытку верно, но Auth :: User вернуть ноль?

Как сказано в названии, в VendorController postLogin метод dd(Auth::user()) получить значение NULL, но $attempt получить результат trueЯ не могу получить данные, которые были попытки.

мой routes/web.php

Route::group(['prefix' => 'vendor','as' => 'Vendor.'], function () {
Route::get('login', 'VendorController@login')->name('Login');
Route::post('login', 'VendorController@postLogin')->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,
],
],

];

1

Решение

Потому что вы используете пользовательский драйвер, и вы не используете Auth::shouldUse() чтобы определить, какой драйвер должен использовать метод, вам нужно вызвать аутентифицированного пользователя следующим образом:

Auth::guard('vendor')->user()

В другом решении вы можете использовать Auth::shouldUse() метод.

public function postLogin(Request $request)
{
Auth::shouldUse('vendor');

if(! $attempt = Auth::attempt([
'acctId'   => $request->acctId,
'password' => $request->password
])){
//handle error if there is not login
}

dd(Auth::user());
}

Делая это, вы устанавливаете драйвер для использования вендора.

4

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]