kyl*_*yle 2 authentication laravel-5 laravel-nova
我正在使用 laravel 5.8 和 nova,并且需要两个用户模型:a_users 和 b_users。a_users 应该能够登录到 laravel 应用程序,b_users 应该能够登录到 nova。
不同的用户不能在同一个数据库表中。<-- 这是我无法控制的要求。
目前,我有两个单独的注册表单,用于注册用户并将其添加到各自的表中。b_users 能够登录 nova 应用程序,而 a_users 从未经过身份验证(未找到)。
有两个单独的登录控制器(一个用于 nova,一个用于 nova,一个用于 App/Http/Controllers/Auth),我也一直在挖掘 AuthenticatesUsers 文件。
我不确定是否应该以某种方式扩展 AuthenticatesUsers 或使用控制器、防护装置或其他东西来实现此目的。
我感谢任何帮助,谢谢!
小智 6
我使用下面的代码来绕过你的问题。快乐编码!
// database\migrations\2019_07_23_075330_create_a_users_table.php
public function up()
{
Schema::create('a_users', function (Blueprint $table) {
$table->bigIncrements('id');
$table->string('name');
$table->string('email')->unique();
$table->string('password');
$table->rememberToken();
$table->timestamps();
});
}
// database\migrations\2019_07_23_075443_create_b_users_table.php
public function up()
{
Schema::create('b_users', function (Blueprint $table) {
$table->bigIncrements('id');
$table->string('name');
$table->string('email')->unique();
$table->string('password');
$table->rememberToken();
$table->timestamps();
});
}
// .env
NOVA_GUARD=loginnova
// config\auth.php
<?php
return [
'defaults' => [
'guard' => 'web',
'passwords' => 'users',
],
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'a_users',
],
'loginnova' => [
'driver' => 'session',
'provider' => 'b_users',
],
'api' => [
'driver' => 'token',
'provider' => 'a_users',
'hash' => false,
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'b_users' => [
'driver' => 'eloquent',
'model' => App\BUser::class,
],
'a_users' => [
'driver' => 'eloquent',
'model' => App\AUser::class,
],
// 'users' => [
// 'driver' => 'database',
// 'table' => 'users',
// ],
],
'passwords' => [
'users' => [
'provider' => 'users',
'table' => 'password_resets',
'expire' => 60,
],
],
];
// app\Nova\AUser.php
<?php
namespace App;
use Illuminate\Auth\Authenticatable;
use Illuminate\Auth\MustVerifyEmail;
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 AUser extends Model implements
AuthenticatableContract,
AuthorizableContract,
CanResetPasswordContract
{
use Authenticatable, Authorizable, CanResetPassword, MustVerifyEmail;
}
// app\BUser.php
<?php
namespace App;
use Illuminate\Auth\Authenticatable;
use Illuminate\Auth\MustVerifyEmail;
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 BUser extends Model implements
AuthenticatableContract,
AuthorizableContract,
CanResetPasswordContract
{
use Authenticatable, Authorizable, CanResetPassword, MustVerifyEmail;
}
Run Code Online (Sandbox Code Playgroud)
注意:我使用 Laravel 的默认身份验证和 Nova 的登录表单!
| 归档时间: |
|
| 查看次数: |
2697 次 |
| 最近记录: |