Почему laravel 6 auth возвращает false после перенаправления с использованием настраиваемой защиты? - PullRequest
4 голосов
/ 10 февраля 2020

Я пытаюсь сделать авторизацию через laravel пакет используя таблицу admins. В каталоге проекта я добавил admin guard в config / auth. php

'providers' => [
        'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
        ],

        'admins' => [
            'driver' => 'eloquent',
            'model' => App\Admin::class,
        ],

        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

И в массиве guard

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'token',
        'provider' => 'users',
        'hash' => false,
    ],

    'admin' => [
        'driver' => 'session',
        'provider' => 'admins',
    ],
    ],

Ниже приведен мой контроллер входа в систему в pacakge

class LoginController extends Controller
{

   use AuthenticatesUsers;
   protected $redirectTo = '/admin/dashboard';
   protected function redirectTo()
   {
         return '/admin/dashboard';
   }

   public function __construct()
   {
       $this->middleware('guest')->except('logout');
   }
   public function login(Request $request)
   {   
       if(Auth::guard('admin')->attempt($request->only('email','password'), true)){
           return redirect()
               ->intended(route('dashboard'))
               ->with('status','You are Logged in as Admin!');
       }
   }

}

и ниже мой контроллер приборной панели

class DashboardController extends Controller
{
    public function __construct()
    {
        /* dd(Auth::check()); */ //return false : just want to show you

          $this->middleware('auth:admin');
    }

    public function index()
    {
        return view('xyz::dashboard');
    }

}

И у моего администратора. php Сценарий, следующий за моделью, есть

namespace App;

class Admin extends \ABC\xyz\App\Models\Admin
{

}

Which is extending package model

namespace ABC\xyz\App\Models;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Admin extends Authenticatable
{

    protected $table = 'admins';
}

А ниже приведены маршруты из моего пакета

    $namespace = 'ABC\Xyz\App\Http\Controllers';
    Route::group([    
    'namespace' => $namespace,
    'middleware' => ['web'], 
    'prefix' => 'admin'
], function () {
    Route::get('login', function(){
        return view('xyz::auth.login');
    })->name('login');

    Route::post('/login', 'Auth\LoginController@login')->name('customLogin');
});

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth']  ], function () {
    Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

Когда я пытаюсь войти в систему, после отправки действительных данных он не перенаправляет меня на панель инструментов, ничего не происходит. Кроме того, когда я пытаюсь открыть принудительно / панель инструментов, я перехожу на страницу входа.

Также сразу после попытки входа в систему, когда я пытаюсь Auth::check(), он возвращает true, но то же самое возвращает false в функции конструкции dashboardController.php. Точно так же Auth::guard('admin')->user() возвращает информацию о пользователе, в то время как на dashboardController.php она возвращает ноль.

Странный результат php Ремесленный маршрут: список

Как видно из конструкции DashboardController.php, я добавил $this->middleware('auth:admin');

Итак, когда Я пытаюсь добавить dd(Auth::guard('admin')->user()) и затем проверить в терминале php artisan route:list, он возвращает ноль и иногда ложь, есть идеи, почему это происходит?

Я не знаю, что и где я что-то упускаю.

Я хотел бы попросить вас помочь мне в этом. Буду признателен.

Спасибо

Ответы [ 4 ]

5 голосов
/ 12 февраля 2020

Проблема в вашем файле маршрутов:

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth']  ], function () {
    Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

Вы используете защиту по умолчанию с промежуточным программным обеспечением auth. После того, как вы вошли в систему admin guard, вы не можете войти в систему по умолчанию web guard. Вот почему это не удается и пытается перенаправить вас на страницу входа в систему:

Когда я пытаюсь войти в систему, после отправки действительных данных он не перенаправляет меня на панель инструментов, ничего не происходит. Кроме того, когда я пытаюсь открыть принудительно / панель инструментов, я перехожу на страницу входа.

Вместо этого вы должны указать в своей группе, что вы используете admin guard:

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth:admin']], function () {
    Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

Однако вы уже указали в DashboardController использование $this->middleware('auth:admin');, поэтому нет необходимости указывать его снова в группе маршрутов. Следующего достаточно и снижает вероятность возникновения ошибки:

Route::group(['namespace' => $namespace,'prefix' => 'admin'], function () {
    Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});
0 голосов
/ 12 февраля 2020

Обратите внимание, что проверка Auth :: не работает на конструкции. это потому, что промежуточное ПО еще не запущено, поэтому Auth :: check () должен возвращать false или null, когда вы пытаетесь проверить в конструкции.

В вашем контроллере входа, почему вы используете два redirectto?

   protected $redirectTo = '/admin/dashboard';
   protected function redirectTo()
   {
     return '/admin/dashboard';
   }

лучше придерживаться одного :-)

внутри вашего администратора. php, добавьте это:

protected $guard = 'admin';

для вашей сети. php маршруты, замените

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth']  ], function () {
Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

на

Route::group(['namespace' => $namespace,'prefix' => 'admin',  'middleware' => ['auth:admin']  ], function () {
Route::get('dashboard', 'DashboardController@index')->name('dashboard');
});

наконец, в DashboardController. php

замените

        /* dd(Auth::check()); */ //return false : just want to show you

на:

    $this->middleware(function ($request, $next) {
        dd(Auth::check());  //return false : just want to show you
        die;    
    });

Auth :: check () должен вернуть true!

0 голосов
/ 12 февраля 2020

Auth :: guard ('admin') -> попытка (только $ request-> ('email', 'password')) вернуть true или false? Если возвращается false, то, возможно, игрушка не хэшировала ваш пароль Попробуйте добавить это в ваша модель

 public function setPasswordAttribute($password)
    {
        $this->attributes['password'] = Hash::make($password);
    }
0 голосов
/ 10 февраля 2020

Пример извлечения того, как вы должны определить свою модель администратора:

 // app/Admin.php
<?php

namespace App;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;

class Admin extends Authenticatable
{
    use Notifiable;

    protected $guard = 'admin';

    protected $fillable = [
        'name', 'email', 'password',
    ];

    protected $hidden = [
        'password', 'remember_token',
    ];
}

Подробнее о нескольких средствах проверки подлинности см. Как использовать несколько средств проверки подлинности

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...