信息发布→ 登录 注册 退出

Laravel怎么修改默认的用户(User)模型

发布时间:2025-11-09

点击量:
将User模型替换为Account需创建新模型并继承Authenticatable;2. 在config/auth.php中更新providers的model指向App\Models\Account;3. 更新控制器、路由等文件中对User类的引用;4. 若表名非users需在模型中设置$table属性。

Laravel 默认使用 App\Models\User 作为用户认证模型,但如果你需要修改这个模型的位置或类名,比如想改成 App\Models\Account 或其他命名空间下的类,可以通过几个步骤轻松实现。

1. 修改 User 模型的路径和类名

如果你想将默认的 User 模型移到别的目录或改名:

  • 创建新的模型类,例如:app/Models/Account.php
  • 确保该模型继承自 Illuminate\Foundation\Auth\User 并使用 Authenticatable trait:

namespace App\Models;

use Illuminate\Foundation\Auth\User as Authenticatable;

class Account extends Authenticatable
{
// 可以在这里定义 fillable、hidden 等属性
}

2. 更新配置文件 auth.php

Laravel 的用户认证配置在 config/auth.php 中。你需要修改其中的 providers 配置项,指向新的模型:

'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\Models\Account::class,
],
],

这样 Laravel 在处理登录、注册、守卫认证时就会使用你的新模型。

3. 更新路由和控制器中的引用

如果你在控制器、中间件或策略中手动引用了 User::class,记得把这些地方也更新为新的模型类:

  • 注册控制器(RegisterController)中实例化的模型
  • 用户请求验证或授权逻辑
  • 任何使用 use App\Models\User; 的文件

4. 数据库迁移(可选)

如果新模型对应的数据表不是 users 表,还需要在模型中指定表名:

protected $table = 'accounts';

否则,默认会查找 users 表。

基本上就这些。只要改对 config/auth.php 和模型定义,Laravel 就能正确识别新的用户模型。不复杂但容易忽略配置文件。

标签:# table  # 时就  # 可选  # 或其他  # 可以通过  # 要在  # 你在  # 就能  # 在这里  # 如果你  # Foundation  # 数据库  # laravel  # Namespace  # protected  # class  # 继承  # 命名空间  # 中间件  # 配置文件  # 路由  # ai  # app  # php  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!