Страница не перенаправляется должным образом при создании промежуточного программного обеспечения для входа администратора и входа пользователя - PullRequest
0 голосов
/ 28 июня 2018

Я хочу сделать систему входа администратора и систему входа пользователя. У обоих разные таблицы. Для аутентификации пользователя я использовал обычную аутентификацию, а для аутентификации администратора - Middleware. Мой код ниже, скажите, пожалуйста, в чем ошибка в этом коде

// RedirectIfNotAdmin

public function handle($request, Closure $next, $guard = 'admin')
{
    if (!Auth::guard($guard)->check()) {
        return redirect('/admin');
    }
    return $next($request);
}

Маршрут

Route::group(['middleware' => ['web']], function () {
Route::get('admin/login', array('as' => 'login.index', 'uses' => 'Admin\LoginController@showLoginForm'));
Route::post('admin/login', array('as' => 'login.entry', 'uses' => 'Admin\LoginController@login'));
Route::get('/admin/logout','Admin\LoginController@logout');
Route::get('admin/register', 'Admin\RegisterController@showRegistrationForm');
Route::post('admin/register', 'Admin\RegisterController@register');
Route::get('/admin', 'AdminController@index');

});

Kernel

protected $routeMiddleware = [
    'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
    'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
    'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
    'can' => \Illuminate\Auth\Middleware\Authorize::class,
    'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
    'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
    'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
    'admin' => \App\Http\Middleware\RedirectIfNotAdmin::class,
];

Контроллер администратора

class AdminController extends Controller{
public function __construct(){
    $this->middleware('admin');
}
public function index(){
    return view('home');
}}

Контроллер входа

protected $redirectTo = '/admin';
public $guard = 'admin';

public function showLoginForm()
{
    if (view()->exists('admin.auth.authenticate')) {
        return view('admin.auth.authenticate');
    }

    return view('admin.auth.login');
}
public function showRegistrationForm()
{
    return view('admin.auth.register');
}
...