php - 验证来自 laravel 5 中两个以上表的用户

标签 php laravel authentication laravel-5.2

<分区>

据我所知,Auth::attempt 用于验证来自 users 表的用户,但我想验证来自 managers 表的另一个用户和 admins 表中的管理员。我知道 laravel-multiauth 插件已经存在。但是我们可以创建自己的 AuthServiceProvider 来对来自多个表的用户进行身份验证吗?

最佳答案

首先在Illuminate\Foundation\Auth中创建Admin Authenticatable

    <?php

namespace Illuminate\Foundation\Auth;
use Illuminate\Auth\Authenticatable;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Auth\Passwords\CanResetPassword;
use Illuminate\Foundation\Auth\Access\Authorizable;
use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract;
use Illuminate\Contracts\Auth\Access\Authorizable as AuthorizableContract;
use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract;

    class Admin extends Model implements
        AuthenticatableContract,
        AuthorizableContract,
        CanResetPasswordContract
    {
        use Authenticatable, Authorizable, CanResetPassword;
    }

然后通过扩展 Authenticatable Admin Model 来创建 Admin Model:-

  <?php
namespace App;
use Illuminate\Foundation\Auth\Admin as Authenticatable;

class Admin extends Authenticatable
{
    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name', 'email', 'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];
}

之后你需要修改 config/auth.php 如下 添加 providers 数组

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

并添加到 guards 数组中。

 'user' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
 'admin' => [
            'driver' => 'session',
            'provider' => 'admins',
        ],

现在从 user 表进行身份验证

 if (Auth::guard('user')->attempt(['email' => $email, 'password' => $password])) {
        $details = Auth::guard('user')->user();
        $user = $details['original'];
        return $user;
    } else {
        return 'auth fail';
    }

并从 Admin 表进行身份验证

 if (Auth::guard('admin')->attempt(['email' => $email, 'password' => $password])) {
        $details = Auth::guard('admin')->user();
        $user = $details['original'];
        return $user;
    } else {
        return 'auth fail';
    }

关于php - 验证来自 laravel 5 中两个以上表的用户,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46292391/

相关文章:

php 和 js//csv 到表(带有附加内容)到 csv

php - MySQL/Eloquent 通过左连接强制 id,即使为 null

php - 从数据库中获取数据并传递给 View

java - Tomcat JDBCRealm 身份验证在部署后不起作用

linux - Influxdb 不要求身份验证

php - Sum mysql 只适用于第一行或者只是出错

php - 使用 PHP 从 SQL 中选择随机行,但从特定点到点 ID

php - Laravel 4.2 根据请求频率生成新的 CSRF token ?

angular - 前端框架世界中的身份验证

php - SELECT COUNT() 与 mysql_num_rows();