0

0

扩展 Django 用户模型:添加自定义字段

聖光之護

聖光之護

发布时间:2025-09-29 16:22:00

|

1001人浏览过

|

来源于php中文网

原创

扩展 django 用户模型:添加自定义字段

本文将介绍如何在 Django 中扩展默认的 User 模型,无需使用一对一关联,直接添加自定义字段。通过创建自定义用户模型并配置 AUTH_USER_MODEL,你可以轻松地在用户注册和管理中包含额外的 boolean 或 choice fields,并确保这些字段在 admin 后台正确显示和管理。

创建自定义用户模型

Django 允许你通过继承 AbstractUser 或 AbstractBaseUser 类来创建自定义用户模型。AbstractUser 已经包含了 Django 默认的用户模型中的大部分字段和方法,因此通常是扩展用户模型的首选。

在你的 Django 应用的 models.py 文件中,创建如下所示的自定义用户模型:

from django.contrib.auth.models import AbstractUser
from django.db import models

class CustomUser(AbstractUser):
    # 添加你的自定义字段
    is_premium = models.BooleanField(default=False, verbose_name="高级用户")
    subscription_type = models.CharField(
        max_length=20,
        choices=[
            ('basic', 'Basic'),
            ('premium', 'Premium'),
            ('enterprise', 'Enterprise'),
        ],
        default='basic',
        verbose_name="订阅类型"
    )

    def __str__(self):
        return self.username

在这个例子中,我们添加了两个自定义字段:

  • is_premium: 一个布尔字段,表示用户是否为高级用户。
  • subscription_type: 一个字符串字段,使用 choices 参数定义了用户订阅类型的选项。

配置 AUTH_USER_MODEL

为了让 Django 使用你的自定义用户模型,你需要修改 settings.py 文件,设置 AUTH_USER_MODEL 变量:

AUTH_USER_MODEL = 'your_app_name.CustomUser'  # 将 your_app_name 替换为你的应用名称

注意: 这一步非常重要,确保 Django 使用你的自定义用户模型而不是默认的 User 模型。

KGOGOMALL
KGOGOMALL

主要功能:无限级分类,可自由调整分类位置,商品可在各分类间自由转移; 商品组合:可以为每种商品添加多种选项,方便顾客购买选择,比如:一件衣服顾客可以选择款式、花色、大小等,笔记本电脑,可以有cpu、内存、显示屏、硬盘等等扩展属性; 会员分级功能,会员积分功能。可根据会员积分自行设定用户组,管理员可自行定义会员获得积分的方式:按订单总金额或者按单个商品给予积分; 按照商品类别查看热卖、特价,允

下载

执行数据库迁移

在修改了用户模型后,你需要执行数据库迁移来更新数据库结构:

python manage.py makemigrations
python manage.py migrate

makemigrations 命令会生成迁移文件,描述了你对模型所做的更改。migrate 命令会将这些更改应用到数据库。

在 Admin 后台注册自定义用户模型

为了在 Django Admin 后台管理你的自定义用户模型,你需要将其注册到 admin.py 文件中。通常,你需要继承 UserAdmin 类并进行一些自定义:

from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from .models import CustomUser

class CustomUserAdmin(UserAdmin):
    model = CustomUser
    list_display = ['username', 'email', 'is_staff', 'is_premium', 'subscription_type'] # 自定义显示的字段
    fieldsets = (
        (None, {'fields': ('username', 'password')}),
        ('Personal info', {'fields': ('first_name', 'last_name', 'email')}),
        ('Permissions', {'fields': ('is_active', 'is_staff', 'is_superuser', 'groups', 'user_permissions')}),
        ('Important dates', {'fields': ('last_login', 'date_joined')}),
        ('Custom Fields', {'fields': ('is_premium', 'subscription_type')}), # 添加自定义字段
    )

admin.site.register(CustomUser, CustomUserAdmin)

在这个例子中,我们创建了一个 CustomUserAdmin 类,继承自 UserAdmin。 我们修改了 list_display 属性,使其在用户列表页面显示自定义字段。我们还修改了 fieldsets 属性,将自定义字段添加到用户编辑页面。

注意事项

  • 在项目初期进行自定义: 建议在项目初期就决定是否需要自定义用户模型。在项目后期更改 AUTH_USER_MODEL 可能会导致数据迁移问题。
  • 继承的选择: AbstractUser 提供了默认字段,而 AbstractBaseUser 则需要你完全定义用户模型。根据你的需求选择合适的基类。
  • 密码处理: 如果你选择 AbstractBaseUser,请确保正确处理密码的哈希和验证。
  • 迁移冲突: 在多人协作开发时,请注意数据库迁移的冲突,并及时解决。
  • 测试: 务必对自定义用户模型进行充分的测试,确保其功能正常。

总结

通过创建自定义用户模型并配置 AUTH_USER_MODEL,你可以轻松地扩展 Django 的用户模型,添加自定义字段,并在 admin 后台进行管理。这种方法避免了使用一对一关联带来的复杂性,使得用户信息的管理更加灵活和方便。 记住,在项目初期就进行自定义用户模型的决策,并进行充分的测试,以确保项目的稳定性和可维护性。

相关专题

更多
java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

348

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

23

2025.11.30

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

253

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

206

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1463

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

616

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

548

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

543

2024.04.29

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 3万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号