Auth :: guard ('memberweb') -> user (), возвращающий нуль после перенаправления - PullRequest
0 голосов
/ 13 мая 2018

Я использую пакеты laravel-modules "https://nwidart.com/laravel-modules/v3/introduction", чтобы лучше структурировать свое приложение.

У меня есть пользовательская модель, созданная с помощью команды «make :: auth», которая находится в App, и модель Member, которая находится в папке «Модули». enter image description here

Проблема заключается в том, что после того, как я войду в систему с использованием функции guard и перенаправлюсь в / member / profile Auth :: guard ('memberweb') -> user () всегда возвращает значение NULL. Но если я dd (Auth :: guard ('memberweb') -> user ()) в методе входа MemberLoginController:

/**
 * Member Login
 *
 * @return void
 */
public function login(Request $request)
{
      $this->validate($request, [
          'email' => 'required|email',
          'password' => 'required',
      ]);

    // Attempt to log the member in
      if (Auth::guard('memberweb')->attempt(['email' => $request->email, 'password' => $request->password], $request->remember)) {
        // if successful, then redirect to their intended location
        dd(Auth::guard('memberweb')->user());
        return redirect()->intended(route('memberProfile'));
      }
      // if unsuccessful, then redirect back to the login with the form data
      return redirect()->back()->withInput($request->only('email', 'remember'))->with('error','your credentials donnot match our records');
}

объект возвращается как ожидалось. Похоже, после перенаправления участник получает выход.

И мой config.auth.guards выглядит так:

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

    'api' => [
        'driver' => 'token',
        'provider' => 'users',
    ],
    'memberweb-api' => [
        'driver' => 'token',
        'provider' => 'members',
    ],
],

И мой Kernel.php:

protected $routeMiddleware = [
    'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
    'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
    'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
    'can' => \Illuminate\Auth\Middleware\Authorize::class,
    'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
    'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
    'memberAuth' => \Modules\Member\Http\Middleware\RedirectIfMemberAuthenticated::class,
    'role' => \App\Http\Middleware\Roles::class,
    'permission' => \App\Http\Middleware\Permissions::class,
];

Что я делаю не так?

1 Ответ

0 голосов
/ 23 июня 2018

Проблема была в файле rout.php.Вы также должны добавить веб-защиту перед авторизацией.

, например, мой route.php выглядел так:

<?php

Route::group(['middleware' => ['auth','role:developer|admin']], 
function()
{
Route::get('/dashboard/users', 'Modules\User\Http\Controllers\UserController@index')->name('dashboardUsers');
Route::get('/dashboard/user/{id}/edit', 'Modules\User\Http\Controllers\UserController@edit')->name('dashboardEditUserView');
Route::post('/dashboard/user/{id}/edit', 'Modules\User\Http\Controllers\UserController@update')->name('dashboardEditUserView');
});

, но должен выглядеть так:

<?php

Route::group(['middleware' => ['web','auth','role:developer|admin']], 
function()
{
Route::get('/dashboard/users', 'Modules\User\Http\Controllers\UserController@index')->name('dashboardUsers');
Route::get('/dashboard/user/{id}/edit', 'Modules\User\Http\Controllers\UserController@edit')->name('dashboardEditUserView');
Route::post('/dashboard/user/{id}/edit', 'Modules\User\Http\Controllers\UserController@update')->name('dashboardEditUserView');
});
...