мульти аутентификация в laravel - PullRequest
0 голосов
/ 07 февраля 2020

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

поэтому мой вопрос, как я могу включить автоматический вход в систему c для других типов пользователей после завершения шага регистрации? ниже приведен код, который я использую в своем проекте

Файл маршрута

Route::get('/', function () {
    return view('welcome');
});

Auth::routes();

Auth::routes(['verify' => true]);

Route::get('/home', 'HomeController@index')->name('home')->middleware('verified');

Route::get('/seller/dashboard', 'SellerHomeController@index')->name('seller.dashboard');
Route::get('/seller/login','Auth\Seller\SellerLoginController@showLoginForm')->name('seller.login');
Route::post('/seller/login','Auth\Seller\SellerLoginController@login');
Route::post('/seller/logout','Auth\Seller\SellerLoginController@logout')->name('seller.logout');
Route::post('/seller/password/email','Auth\Seller\SellerForgotPasswordController@sendResetLinkEmail')->name('seller.password.email');
Route::get('/seller/password/reset', 'Auth\Seller\SellerForgotPasswordController@showLinkRequestForm')->name('seller.password.request');
Route::post('/seller/password/reset','Auth\Seller\SellerResetPasswordController@reset')->name('seller.password.update');
Route::get('/seller/password/reset/{token}', 'Auth\Seller\SellerResetPasswordController@showResetForm')->name('seller.password.reset');
Route::get('/seller/register','Auth\Seller\SellerRegisterController@showRegistrationForm')->name('seller.register');
Route::post('/seller/register','Auth\Seller\SellerRegisterController@register');

SellerLoginController

namespace App\Http\Controllers\Auth\Seller;

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class SellerLoginController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles authenticating users for the application and
    | redirecting them to your home screen. The controller uses a trait
    | to conveniently provide its functionality to your applications.
    |
    */

    use AuthenticatesUsers;

    /**
     * Where to redirect users after login.
     *
     * @var string
     */
    protected $redirectTo = '/seller/dashboard';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest:seller')->except('logout');
    }

    public function showLoginForm()
    {

        return view('auth.seller.login');
    }

    protected function attemptLogin(Request $request)
    {
        return $this->guard('seller')->attempt(
            $this->credentials($request), $request->filled('remember')
        );
    }

    protected function guard()
    {
        return Auth::guard('seller');
    }
}

ПродавецРегистрацияКонтроллер

namespace App\Http\Controllers\Auth\Seller;

use App\Seller;
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;
use Illuminate\Auth\Events\Registered;

class SellerRegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after registration.
     *
     * @var string
     */
    protected $redirectTo = '/seller/dashboard';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest:seller');
    }

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

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'firstname' => ['required', 'string', 'max:255'],
            'lastname' => ['required', 'string', 'max:255'],
            'email' => ['required', 'string', 'email', 'max:255', 'unique:sellers'],
            'business_name' => ['required', 'string', 'max:255'],
            'business_description' => ['required', 'string', 'max:255'],
            'business_location' => ['required', 'string', 'max:255'],
            'business_website' => ['required', 'string', 'max:255'],
            'password' => ['required', 'string', 'min:6', 'confirmed'],

        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return \App\User
     */
    protected function create(array $data)
    {
        $seller =  Seller::create([
            'firstname' => $data['firstname'],
            'lastname' => $data['lastname'],
            'email' => $data['email'],
            'business_name' => $data['business_name'],
            'business_description' => $data['business_description'],
            'business_location' => $data['business_location'],
            'business_website' => $data['business_website'],
            'business_logo' => 'test_logo.jpg',
            'password' => Hash::make($data['password']),
            'user_type' => $data['user_type'],
        ]);
       return $seller;
    }
}// code end here

Ответы [ 3 ]

1 голос
/ 07 февраля 2020

Это происходит потому, что вы не определили метод guard в SellerRegisterController, и реализация по умолчанию извлекает драйвер по умолчанию (то есть web).

Этот метод защиты обеспечивает защиту для автоматический вход в систему c в методе register RegistersUsers:

$this->guard()->login($user);

Необходимо переопределить метод guard в классе SellerRegisterController, чтобы вернуть правильный драйвер и разрешить признак выполнения процесса входа на правильный драйвер sellers:

/**
 * Get the guard to be used during registration.
 *
 * @return \Illuminate\Contracts\Auth\StatefulGuard
 */
protected function guard()
{
    return Auth::guard('sellers');
}
0 голосов
/ 08 февраля 2020
// Adminmiddleware
 if(Auth::check() && Auth::user()->role->id == 1)
      {
        return $next($request);
      }else {
        return redirect()->route('login');
      }

//  Authormiddleware
 if(Auth::check() && Auth::user()->role->id == 2 )
      {
        return $next($request);
      }else {
        return redirect()->route('login');
      }

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


});
// Auhtor Route
Route::group(['as'=>'user.','prefix'=>'user','namespace'=>'Author','middleware'=>['auth','user']], function (){
    Route::get('dashboard','DashboardController@index')->name('dashboard');
});

// only auht route
Route::group(['middleware'=>['auth']], function(){
    Route::post('favorite/{post}/add','FavoriteController@add')->name('post.favorite');
    Route::post('review/{id}/add','ReviewController@review')->name('review');
    Route::get('file-download/{id}', 'PostController@downloadproject')->name('project.download');
    Route::post('file-download/{id}', 'PostController@downloadproject');
});
0 голосов
/ 07 февраля 2020

Laravel Аутентификация по умолчанию принимает таблицу пользователя в качестве основных данных. Если вы хотите сделать несколько аутентификаций, первое, что вам нужно сделать, это создать модель с чертой Notifiable

Model

class Admin extends Authenticatable
{
   use Notifiable;
}

После этого вам нужно создать сторож и провайдера в config/auth.php Пример, подобный этому

<?php

[...]
'guards' => [
    [...]
    'admin' => [
        'driver' => 'session',
        'provider' => 'admins',
    ],
    'writer' => [
        'driver' => 'session',
        'provider' => 'writers',
    ],
],
[...]

И

[...]
'providers' => [
    [...]
    'admins' => [
        'driver' => 'eloquent',
        'model' => App\Admin::class,
    ],
    'writers' => [
        'driver' => 'eloquent',
        'model' => App\Writer::class,
    ],
],
[...]

И в контроллере входа вам нужно проверить, какой охранник пытается войти, выполнив эту строку

Auth::guard('admin')->attempt(['email' => $request->email, 'password' => $request->password], $request->get('remember'))

Если вам нужно больше подробностей, попробуйте прочитать это https://pusher.com/tutorials/multiple-authentication-guards-laravel

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