首页 > 解决方案 > 来自两个以上表的 Laravel Multi Auth

问题描述

我想用 laravel 编写一个 Web 服务,
我正在尝试分别对用户管理表单users表和admins表进行身份验证。
在此 Web 服务中,用户和管理员身份验证是不同的。验证管理员email和用户由phone number.Admins 通过Web路由访问管理面板,用户使用API路由。

据我所知Auth::attempt,用于adminsadmins表中进行身份验证,但我想从表中对其他用户进行身份验证,users并从表中对管理员进行身份验证admin
任何人都可以通过示例从两个以上的表中解释 Multi Auth 吗?

我知道这Auth::attempt用于users从用户表进行身份验证,但我更改了名称。

到目前为止我所做的

Guards
config/auth.php

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

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

提供者

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

路由
web.php(管理员)

Route::group(['namespace' => 'Auth'] , function (){

    // Authentication Routes...
    $this->get('login', 'LoginController@showLoginForm')->name('login');
    $this->post('login', 'LoginController@login');
    $this->get('logout', 'LoginController@logout')->name('logout');

    // Registration Routes...
    $this->get('register', 'RegisterController@showRegistrationForm')->name('register');
    $this->post('register', 'RegisterController@register');

    // Password Reset Routes...
    $this->get('password/reset', 'ForgotPasswordController@showLinkRequestForm')->name('password.request');
    $this->post('password/email', 'ForgotPasswordController@sendResetLinkEmail')->name('password.email');
    $this->get('password/reset/{token}', 'ResetPasswordController@showResetForm')->name('password.reset');
    $this->post('password/reset', 'ResetPasswordController@reset');
});

api.php(用户)

Route::group(['prefix' => 'android/v1' , 'namespace' => 'Api\Android\v1'] , function (){
    $this->post('login' , 'UserController@login');
    $this->post('register' , 'UserController@register');
});


用户控制器api/android/v1/ UserController.php

public function login(Request $request)
{
    $validData = $this->validate($request, [
        'mobile' => 'required|exists:users',
        'password' => 'required'
    ]);
    if(! auth()->attempt($validData)) {
        return response([
            'data' => 'data not true',
            'status' => 'error'
        ],403);
    }

    return new UserResource(auth()->user());
}

标签: phplaravelauthenticationlaravel-5.6

解决方案


我的第一个建议是为您的管理员和用户设置不同的控制器,然后您可以指定为什么要使用警卫来处理请求。


推荐阅读