首页 > 解决方案 > 如何使用登录和注册功能更改 laravel 8 中的身份验证表

问题描述

我正在尝试使用 laravel 8 为开源游戏构建一个控制面板,该游戏已经有一个具有不同身份验证表名称和列的数据库。我的目的是拥有这个面板以便注册、登录(显示一些数据)、恢复密码电子邮件和更改密码电子邮件。用户表现在是一个帐户表,我在 stackoverflow 和其他论坛上看到了数百个帖子,他们说要遵循相同的步骤。新迁移文件,新模型文件,更改 config/auth.php 设置

问题是,当我用帐户表更改用户表时,一切似乎都有效。用户可以注册并登录,但是当我尝试使用 {{Auth::user()}} 在我的 Blade.php 中获取用户信息时,它显示一个 0 数字,如果我想显示 {{Auth::user->无论哪一列}},它都会选择表中的第一行。我现在从互联网上搜索了 3 天的答案,但没有任何结果,并尝试了许多不同的方法来完成这项工作。我在某处看到关于身份验证的 laravel 核心,您需要重命名每个包含用户的类。我被困住了。这是我的代码。

登录控制器(我使用了另一种哈希方法而不是 bcrypt,因为游戏服务器支持这个)

<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Auth;
use App\Models\User;

class LoginController extends Controller
{
public function login()
{

  return view('auth.login');
}

public function authenticate(Request $request)
{
    $request->validate([
        'email' => 'required|string',
        'password' => 'required|string',
    ]);

    $user = User::where([ 
      'email'  => $request->email,
      'password'  => base64_encode(hash("sha1", $request->password, true))
  ])->first(); 
  
  

  if ($user) { 
      Auth::login($user); 

      return redirect()->intended('home')->with('success', 'Your Account has been registered.');
  }

    return redirect('login')->with('error', 'Oppes! You have entered invalid credentials');
}

public function logout() {
  Auth::logout();

  return redirect('login');
}

}

我的用户类

 <?php

 namespace App\Models;

 use Illuminate\Contracts\Auth\MustVerifyEmail;
 use Illuminate\Database\Eloquent\Factories\HasFactory;
 use Illuminate\Foundation\Auth\User as Authenticatable;
 use Illuminate\Notifications\Notifiable;
 use Laravel\Sanctum\HasApiTokens;
 use Auth;

 class User extends Authenticatable
{
use HasApiTokens, HasFactory, Notifiable;

/**
 * The attributes that are mass assignable.
 *
 * @var string[]
 */
protected $fillable = [
    'users',
    'email',
    'password',
];

protected $primaryKey = 'login';
protected $table = 'accounts';
public $timestamps = false;
protected $rememberTokenName = false;


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

/**
 * The attributes that should be cast.
 *
 * @var array
 */
protected $casts = [
    'email_verified_at' => 'datetime',
];


}

我的 auth.php

 <?php

 return [


*/

'defaults' => [
    'guard' => 'web',
    'passwords' => 'accounts',
],



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



'providers' => [
    'accounts' => [
        'driver' => 'eloquent',
        'model' => App\Models\User::class,
    ],

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



'passwords' => [
    'accounts' => [
        'provider' => 'accounts',
        'table' => 'password_resets',
        'expire' => 60,
        'throttle' => 60,
    ],
],



'password_timeout' => 10800,

 ];

标签: phplaravel

解决方案


推荐阅读