Laravel 7 多个身份验证角色

Laravel 7 multiple auth roles

我正在尝试为网站创建自定义身份验证角色,我已经关注了另一个堆栈溢出 post,它似乎可以正常工作,但我的总是失败,我知道自从我倾倒和死亡以来信息就存在Auth::guard 失败后要筛选的信息。问题是即使信息存在,auth guard 也会失败

if (Auth::guard('Admin')->attempt(['Username' => $Request->input('UName'), 'Password' => $Request->input('Password')]))

信息审核通过,顺利通过

 if (Admins::where('Username', $Request->input('UName'))->exists()) {
            $AdminDetails = Admins::Where('Username', $Request->input('UName'))->first();
            if(Hash::check($Request->input('Password'), $AdminDetails->Password)){
                   //user details are correct
            }
  }

我已经让用户和管理员都可以验证上面的代码试图授权管理员,我还更改了 config/auth.php 文件,如下所示

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

        'api' => [
            'driver' => 'token',
            'provider' => 'users',
            'hash' => false,
        ],
        'Admin' => [
            'driver' => 'session',
            'provider' => 'Admin',
        ],
        'User' => [
            'driver' => 'session', 
            'provider' => 'User',
        ],
    ],
'providers' => [
        'User' => [
            'driver' => 'eloquent',
            'model' => App\Models\User::class,
        ],
        'Admin' => [
            'driver' => 'eloquent',
            'model' => App\Models\Admins::class,
        ]

        // 'users' => [
        //     'driver' => 'database',
        //     'table' => 'users',
        // ],
    ],

模型在正确的命名空间内,如下所示,具有管理员身份验证

<?php
namespace App\Models;

use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Admins extends Authenticatable
{
    use Notifiable;

    protected $guard = 'Admin';

    protected $fillable = [
        'FName', 'LName', 'Email', 'Password', 'Username'
    ];

    protected $hidden = [
        'password'
    ];
}

并且用户可验证

<?php

namespace App\Models;


use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class Users extends Authenticatable
{
    use Notifiable;

    protected $guard = 'User';

    protected $fillable = [
        'FullName', 'Email', 'CompanyName','ReferedBy','PhoneNumber','MemberStatus','CustomMessage',
    ];

    protected $hidden = [
        'password', 'remember_token',
    ];
}

Laravel 7 不显示任何错误或任何内容,但尝试登录用户的 if 语句失败

管理模型的迁移也是

<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateAdminsTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('admins', function (Blueprint $table) {
            $table->id();
            $table->string('Username');
            $table->string('FName');
            $table->string('LName');
            $table->string('Email');
            $table->string('Password');
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('admins');
    }
}

我知道要在一个问题中提出很多信息,但我知道它都与问题相关。 感谢您提供的任何帮助。

将凭据数组传递给 Auth::attempt 时,保存密码的元素 必须 被命名为 password,它与任何字段名称无关在 table 上。这就是 User Provider 知道哪个字段应该是“密码”的方式,因为它需要进行哈希检查;凭据中除 password 之外的所有其他字段都是查询的 WHERE 条件。

['Username' => ..., 'password' => ...]

如果您的 Model/table 除了 password 之外还使用了不同的密码字段,您必须通过定义 getAuthPassword 方法来告诉模型:

public function getAuthPassword()
{
    return $this->Password;
}