任何人都可以通过示例解释Laravel 5.2多重身份验证


171

我正在尝试分别认证用户管理表单user表和admin表。我正在使用Userlaravel提供的模型,并为Admin.我添加了保护密钥和提供者密钥而创建了该模型auth.php.

守卫

'guards' => [
    'user' =>[
        'driver' => 'session',
        'provider' => 'user',
    ],
    'admin' => [
        'driver' => 'session',
        'provider' => 'admin',
    ],
],  

提供者

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

路线

Route::group(['middleware' => ['web']], function () {
    // Login Routes.   
    Route::get('/admin/login','AdminAuth\AuthController@showLoginForm');
    Route::post('/admin/login','AdminAuth\AuthController@login');
    Route::get('/admin/logout','AdminAuth\AuthController@logout');

    // Registration Routes.
    Route::get('admin/register', 'AdminAuth\AuthController@showRegistrationForm');
    Route::post('admin/register', 'AdminAuth\AuthController@register');

    Route::get('/admin', 'AdminController@index');
});

我创建了一个名为AuthAdminLaravel的默认目录AuthController.phpPasswordController.php文件的目录。(命名空间已相应修改)

首先,在Laravel的文档中提到了如何在进行身份验证时指定自定义防护,这是行不通的。
在此处输入图片说明

Laravel的文档中提到了另一种使用防护功能的方法。

在此处输入图片说明

如果有人能解决问题并纠正我的想法,那将是有益的。


Laravel修复了5.2.6版中的一个错误。protected $guard = 'guard_name'现在可以使用。
imrealashu

在Laravel中,有许多管理面板生成器软件包可用。我更喜欢Voyager Admin。轻松安装它们。这样可以节省大量代码。您只需要了解它是如何工作的。不要重新发明轮子。Voyager-丢失的Laravel管理员 具有Gentelella引导程序管理员临时角色的Laravel应用程序。
sathish R

Answers:


201

经过大量的挖掘和大量的问题与答案之后,我终于设法使用带有两个表的Laravel 5.2 Multi Auth,所以我正在编写自己的问题的Answer。

如何在Larvel 5.2中实现Multi Auth

正如刚才提到的。两个表adminusers

Laravel 5.2有一个新artisan命令。

php artisan make:auth

它将生成基本的登录/注册routeviewcontroller用于user表。

为简单起见,将admin表格制作为users表格。

管理员控制器
app/Http/Controllers/AdminAuth/AuthController
app/Http/Controllers/AdminAuth/PasswordController
(注意:我只是从app/Http/Controllers/Auth/AuthController此处复制这些文件)

config/auth.php

//Authenticating guards
'guards' => [
    'user' =>[
        'driver' => 'session',
        'provider' => 'user',
    ],
    'admin' => [
        'driver' => 'session',
        'provider' => 'admin',
    ],
],  

//User Providers
'providers' => [
    'user' => [
        'driver' => 'eloquent',
        'model' => App\User::class,
    ],
    'admin' => [
        'driver' => 'eloquent',
        'model' => App\Admin::class,
    ]
],  

//Resetting Password  
'passwords' => [
    'clients' => [
        'provider' => 'client',
        'email' => 'auth.emails.password',
        'table' => 'password_resets',
        'expire' => 60,
    ],
    'admins' => [
        'provider' => 'admin',
        'email' => 'auth.emails.password',
        'table' => 'password_resets',
        'expire' => 60,
    ],
],  

route.php

Route::group(['middleware' => ['web']], function () {
    //Login Routes...
    Route::get('/admin/login','AdminAuth\AuthController@showLoginForm');
    Route::post('/admin/login','AdminAuth\AuthController@login');
    Route::get('/admin/logout','AdminAuth\AuthController@logout');

    // Registration Routes...
    Route::get('admin/register', 'AdminAuth\AuthController@showRegistrationForm');
    Route::post('admin/register', 'AdminAuth\AuthController@register');

    Route::get('/admin', 'AdminController@index');

});  

AdminAuth/AuthController.php

添加两个方法并指定$redirectTo$guard

protected $redirectTo = '/admin';
protected $guard = 'admin';
public function showLoginForm()
{
    if (view()->exists('auth.authenticate')) {
        return view('auth.authenticate');
    }

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

它将帮助您为管理员打开另一个登录表单

为创建一个中间件 admin

class RedirectIfNotAdmin
{
/**
 * Handle an incoming request.
 *
 * @param  \Illuminate\Http\Request  $request
 * @param  \Closure  $next
 * @param  string|null  $guard
 * @return mixed
 */
public function handle($request, Closure $next, $guard = 'admin')
{
    if (!Auth::guard($guard)->check()) {
        return redirect('/');
    }

    return $next($request);
}

}

在注册中间件 kernel.php

 protected $routeMiddleware = [
    'admin' => \App\Http\Middleware\RedirectIfNotAdmin::class,
];

AdminController 例如使用此中间件

namespace App\Http\Controllers;

use Illuminate\Http\Request;

use App\Http\Requests;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Auth;

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

这是使它正常工作以及获得经过身份验证的管理员使用的json所必需的
Auth::guard('admin')->user()

编辑-1
我们可以使用直接访问经过身份验证的用户,
Auth::user() 但是如果您有两个身份验证表,则必须使用

Auth::guard('guard_name')->user()  

登出

Auth::guard('guard_name')->user()->logout()

用于经过身份验证的用户json

Auth::guard('guard_name')->user()  

编辑2

现在您可以下载Laravel 5.2 Multiauth实现的项目http://imrealashu.in/code/laravel/multi-auth-with-laravel-5-2-2/


非常感谢一个人,这就是我要寻找的东西,它做了一点点修改。非常感谢Q +1和Ans +1,希望我能再+1。非常感谢..
rummykhan '16

@imrealashu,正如我根据您的回答创建项目一样。但是它会产生多个同名类的错误。那呢?如果我更改了admin auth的类名,那么我需要在哪里进行更改?
Akshay Vaghasiya '16

1
您能否也请解释一下如何“重置密码”以保护管理员。
Shoaib Rehan

1
感谢您的出色解释,对我的一切都很有用。要使用中间件来宾,请将RedirectIfAuthenticated.php文件更改为以下行:原始: if (Auth :: guard ($ guard) -> check ()) { return redirect ('/'); } 更改之后:if (Auth :: guard ('yourcustomguard') -> check () || Auth :: check ()) { return redirect ('/'); }
Cristian Meza 2016年

1
@Jeffz只是因为文档不正确,并且没有关于多重身份验证的有效示例。.我们希望文档很好,是的,此5.3更新的新功能很酷。
imrealashu

2

万一这对任何人都有帮助,这可能只是由于我对中间件的了解不足,这是我必须要做的工作(除了@imrealashu采取的步骤)...

route.php

Route::get('/admin', [
  'middleware' => 'admin',
  'uses' => 'AdminController@index'
]);

这是在web中间件组中。在此之前,我尝试将其放在一个单独的admin中间件组中,甚至放在一个auth:admin组中,但这没有用,只有当我在路由本身上将中间件指定为admin时,它才对我有用。我不知道为什么会这样,但是我希望它可以避免其他人像我一样拔头发。


我下载了用ezisting项目文件替换的多身份zip文件,然后在我迁移数据库时出现此错误显示。
G Naga Subrahmanyam,2013年

实际上,对我来说,管理员正在登录,但未重定向到管理员。完成此操作后,能否请您说明为什么?我必须注册其他路线,因为它可能Route::group(['middleware' => ['admin']], function () { //Admin Routes... });对我不起作用
Leap Hawk

0

在laravel 5.6中非常简单。只需转到config/auth.php并在providers数组中添加以下行:

'admins' => [
   'driver' => 'database',
   'table' => 'admin_table'
]

请注意,我们database没有使用驱动程序eloquent

现在将其添加到guards数组:

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

现在我们完成了!在使用admins表时使用此命令:

Auth::guard('admin_guard')->User();

干杯。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.