草庐IT

Django(11):后台管理系统

恐惧来自未知 2023-10-22 原文

目录


Django内置了自己的后台管理系统,包含数据库管理和良好的界面。

后台管理系统基本操作

在我们前面创建Django项目时,默认会有许多应用组件,在配置文件中,如下:

INSTALLED_APPS = [
    'django.contrib.admin',  # 内建后台管理系统
    'django.contrib.auth',  # 内建用户认证模块
    'django.contrib.contenttypes',  # 内建内容类型处理模块
    'django.contrib.sessions',  # 内建会话管理模块
    'django.contrib.messages',  # 内建消息管理接口模块
    'django.contrib.staticfiles',  # 内建静态文件管理模块
    'author',
]

# 中间件配置,如果需要在处理流程中添加额外的功能,则在这里添加
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',  # 内建安全管理中间件
    'django.contrib.sessions.middleware.SessionMiddleware',  # 内建会话管理中间件
    'django.middleware.common.CommonMiddleware',  # 内建请求处理基础功能中间件
    'django.middleware.csrf.CsrfViewMiddleware',  # 内建跨域防护过滤中间件
    'django.contrib.auth.middleware.AuthenticationMiddleware',  # 内建认证过滤中间件
    'django.contrib.messages.middleware.MessageMiddleware',  # 内建消息处理中间件
    'django.middleware.clickjacking.XFrameOptionsMiddleware',  # 内建请求求选项过滤中间件
]

本节的后台管理系统就是通过django.contrib.admin创建到Django中,并且通过django.contrib.auth模块完成用户登录认证,使用django.contrib.sessions实现状态保持。这些都是默认给我们创建好了。

前面已经讲过怎么去初始化我们的后台管理系统,参考文章:通过博客项目熟悉django项目开发基本流程

下面讲下基本操作。

管理平台的基本操作

按照以前的步骤,输入账户名和密码就可以进入我们的后台管理系统。如下:

点击添加用户下的添加,可以添加用户,如下:

成功添加用户后,可以再次编辑,如下:

同时可以编辑用户的权限和分组,便于分组管理。

数据模型的注册和管理

自定义的数据模型也可以注册到后台管理系统进行数据维护操作。以我们前面的博客项目为例,创建一个作者子项目,里面的数据模型author/models.py如下:

from uuid import uuid4
from django.db import models

# Create your models here.


class Author(models.Model):
    """用户类型:博客作者"""

    GENDER = (
        ('0', '女'),
        ('1', '男'),
    )
    AUTHOR_STATUS = {
        ('0', '正常'),
        ('1', '锁定',),
        ('2', '删除'),
    }
    # 作者编号
    id = models.AutoField(primary_key=True, verbose_name='作者编号')
    # 登录账号
    username = models.CharField(max_length=50, verbose_name='登录账号', unique=True, db_index=True)
    # 登录密码
    password = models.CharField(max_length=50, verbose_name='登录密码')
    # 真实姓名
    realname = models.CharField(max_length=20, verbose_name='作者姓名', default='待完善', null=True, blank=True, db_index=True)
    # 年龄
    age = models.IntegerField(default=0, verbose_name='作者年龄')
    # 性别
    gender = models.CharField(max_length=1, choices=GENDER, verbose_name='性别', null=True, blank=True)
    # 邮箱
    email = models.EmailField(verbose_name='联系邮箱', null=True, blank=True, db_index=True)
    # 手机
    phone = models.CharField(max_length=20, verbose_name='联系电话', db_index=True, null=True, blank=True)
    # 用户状态
    status = models.CharField(max_length=5, choices=AUTHOR_STATUS, verbose_name='用户状态', help_text='必须选择其中一个状态',
                              default=0)
    # 个人介绍
    intro = models.TextField(verbose_name='个人介绍', null=True, blank=True)
    # 备注信息
    remark = models.TextField(verbose_name='备注信息', null=True, blank=True)
    # 特别关注的作者
    author_liked = models.OneToOneField('self', on_delete=models.SET_NULL, null=True, blank=True)


    class Meta:
        # 后台管理系统中的名称
        verbose_name_plural = '作者'

在每个子项目中,都有一个后台管理模块admin.py,该模块是后台管理平台和子项目中数据交互的桥梁,在这里把自定义模型注册到后台管理系统。编辑author/admin.py,代码如下:

from django.contrib import admin
from .models import Author

admin.site.register(Author)

但是上述数据模型注册,不能对数据模型进行规范格式的处理,所以需要建一个后台数据管理类进行操作,代码如下:

from django.contrib import admin
from .models import Author


# 数据管理类
class AuthorAdmin(admin.ModelAdmin):
    pass


admin.site.register(Author, AuthorAdmin)

然后还可以通过装饰器进行注册:

from django.contrib import admin

# Register your models here.

from .models import Author


# 数据管理类
@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    pass


# admin.site.register(Author, AuthorAdmin)

最后执行如下命令完成
数据迁移:

python manage.py makemigrations author
python manage.pymigrate

然后就可以在我们的后台管理系统看到作者模型了,可以进行数据的增删改查,这里不再演示,可自行探索。

数据模型管理

默认情况下,数据模型在后台展示的是__str__(self)返回的结果。但是在实际项目中,我们可以通过我们上面建好的数据管理类的内建建属性来定制展示数据的界面数据。主要属性如下:

1.list_display

指定在列表页展示的模型属性有哪些,代码如下:

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')

如下:

2.list_display_links

指定链接属性。在数据列表中,如果字段较多,可使用这个属性为某些字段添加引导链接,直接链接到该数据类型的详情页面。注意链接需要包含在list_display指定的属性中。代码如下:

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')
    list_display_links = ('username', 'realname')

3.list_editable

指定哪些属性可以直接在列表里编辑。字段需要在list_display指定的属性中,不能在list_display_links指定的属性中。代码如下:

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')
    list_display_links = ('username', 'realname')
    list_editable = ('age', 'gender', 'phone')

效果如下:

4.list_filter

指定哪些属性在列表可以添加过滤条件,代码如下:

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')
    list_display_links = ('username', 'realname')
    list_editable = ('age', 'gender', 'phone')
    list_filter = ('age', 'gender')

效果如下:

5.list_max_show_all

当数据很多时,配置此属性时,此页只会展示这么多条数据,然后有个显示全部按钮,用于在一个独立的页面展示所有数据。代码如下:

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')
    list_display_links = ('username', 'realname')
    list_editable = ('age', 'gender', 'phone')
    list_filter = ('age', 'gender')
    list_max_show_all = 5

6.list_per_page

用于分页,每页面试条数。

@admin.register(Author)
class AuthorAdmin(admin.ModelAdmin):
    """数据管理类"""
    list_display = ('username', 'realname', 'gender', 'age', 'phone')
    list_display_links = ('username', 'realname')
    list_editable = ('age', 'gender', 'phone')
    list_filter = ('age', 'gender')
    list_max_show_all = 5
    list_per_page = 10

7.ordering

列表排序规则。会覆盖原生的数据模型的Meat里定义的排序。

ordering = ['username', 'age']

8.fields

设置编辑字段,并在编辑页面对展示的字段进行归类和整理。代码如下:

fields = (('username', 'realname'), ('age', 'gender'), 'phone')

效果如下:

9.exclude

和fields相反,在编辑页排除哪些字段不可编辑或展示。

exclude = ('email',)

10.fieldsets

对属性数据进行很好的分级和分类,不可与fields一起使用。一般格式如下:

fieldsets = (
        ('属性组标题', {
            'key': ('value',)
        }),
)

fieldsets中包含多个元组,每个元组包含两部分数据:其中’属性组标题’用于描述多个属性数据的标题;元组里字典就是展示的属性和展示方式,有如下三个取值:

  • fields:包含指定要展示的属性数据的元组
  • classes:数据展示方式:wide是优化展示;collapse是通过鼠标交互显示和隐藏
  • description:针对数据的描述,显示在标题附近

代码如下:

fieldsets = (
        ('基本资料', {
            'fields': (('username', 'realname'), ('age', 'gender'))
        }),
        ('扩展资料', {
            'classes': ('collapse',),
            'description': '用户的扩展资料,可以再创建后完善',
            'fields': ('phone', 'email')
        }),
        ('高级资料', {
            'fields': ('remark',)
        }),
    )

效果如下:

11.radio_fields

设置单选按钮。代码如下:

radio_fields = {'gender': admin.HORIZONTAL}

HORIZONTAL指定为水平展示。

12.readonly_fields

指定只读属性,不可修改。

readonly_fields = ('username', )

13.save_on_top

在顶部添加操作按钮。

save_on_top = True

14.save_as

可以再编辑页把当前数据另存为,快捷创建一条新的数据。

save_as = True

后台管理系统操作

  1. 系统汉化
    可在配置文件配置:
LANGUAGE_CODE = 'zh-Hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_TZ = True
  1. 后台页面标题和logo
    在任意的app的admin.py模块,引入admin.site来修改:
admin.site.site_header = '社交系统管理平台'
admin.site.site_title = '社交系统后台系统'

Xadmin管理平台

Xadmin是第三方机构独立开发的Django后台管理平台。
学习请参考:xadmin快速搭建后台管理系统

有关Django(11):后台管理系统的更多相关文章

  1. ruby - i18n Assets 管理/翻译 UI - 2

    我正在使用i18n从头开始​​构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在ruby​​onrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi

  2. ruby-on-rails - 获取 inf-ruby 以使用 ruby​​ 版本管理器 (rvm) - 2

    我安装了ruby​​版本管理器,并将RVM安装的ruby​​实现设置为默认值,这样'哪个ruby'显示'~/.rvm/ruby-1.8.6-p383/bin/ruby'但是当我在emacs中打开inf-ruby缓冲区时,它使用安装在/usr/bin中的ruby​​。有没有办法让emacs像shell一样尊重ruby​​的路径?谢谢! 最佳答案 我创建了一个emacs扩展来将rvm集成到emacs中。如果您有兴趣,可以在这里获取:http://github.com/senny/rvm.el

  3. ruby-on-rails - 事件管理员日期过滤器日期格式自定义 - 2

    是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s

  4. 电脑0x0000001A蓝屏错误怎么U盘重装系统教学 - 2

      电脑0x0000001A蓝屏错误怎么U盘重装系统教学分享。有用户电脑开机之后遇到了系统蓝屏的情况。系统蓝屏问题很多时候都是系统bug,只有通过重装系统来进行解决。那么蓝屏问题如何通过U盘重装新系统来解决呢?来看看以下的详细操作方法教学吧。  准备工作:  1、U盘一个(尽量使用8G以上的U盘)。  2、一台正常联网可使用的电脑。  3、ghost或ISO系统镜像文件(Win10系统下载_Win10专业版_windows10正式版下载-系统之家)。  4、在本页面下载U盘启动盘制作工具:系统之家U盘启动工具。  U盘启动盘制作步骤:  注意:制作期间,U盘会被格式化,因此U盘中的重要文件请注

  5. 【鸿蒙应用开发系列】- 获取系统设备信息以及版本API兼容调用方式 - 2

    在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList​()Obt

  6. ruby - 安装libv8(3.11.8.13)出错,Bundler无法继续 - 2

    运行bundleinstall后出现此错误:Gem::Package::FormatError:nometadatafoundin/Users/jeanosorio/.rvm/gems/ruby-1.9.3-p286/cache/libv8-3.11.8.13-x86_64-darwin-12.gemAnerroroccurredwhileinstallinglibv8(3.11.8.13),andBundlercannotcontinue.Makesurethat`geminstalllibv8-v'3.11.8.13'`succeedsbeforebundling.我试试gemin

  7. kvm虚拟机安装centos7基于ubuntu20.04系统 - 2

    需求:要创建虚拟机,就需要给他提供一个虚拟的磁盘,我们就在/opt目录下创建一个10G大小的raw格式的虚拟磁盘CentOS-7-x86_64.raw命令格式:qemu-imgcreate-f磁盘格式磁盘名称磁盘大小qemu-imgcreate-f磁盘格式-o?1.创建磁盘qemu-imgcreate-fraw/opt/CentOS-7-x86_64.raw10G执行效果#ls/opt/CentOS-7-x86_64.raw2.安装虚拟机使用virt-install命令,基于我们提供的系统镜像和虚拟磁盘来创建一个虚拟机,另外在创建虚拟机之前,提前打开vnc客户端,在创建虚拟机的时候,通过vnc

  8. ruby - 如何在 ruby​​ 中运行后台线程? - 2

    我是ruby​​的新手,我认为重新构建一个我用C#编写的简单聊天程序是个好主意。我正在使用Ruby2.0.0MRI(Matz的Ruby实现)。问题是我想在服务器运行时为简单的服务器命令提供I/O。这是从示例中获取的服务器。我添加了使用gets()获取输入的命令方法。我希望此方法在后台作为线程运行,但该线程正在阻塞另一个线程。require'socket'#Getsocketsfromstdlibserver=TCPServer.open(2000)#Sockettolistenonport2000defcommandsx=1whilex==1exitProgram=gets.chomp

  9. ruby - (Ruby || Python) 窗口管理器 - 2

    我想用这两种语言中的任何一种(最好是ruby​​)制作一个窗口管理器。老实说,除了我需要加载某种X模块外,我不知道从哪里开始。因此,如果有人有线索,如果您能指出正确的方向,那就太好了。谢谢 最佳答案 XCB,X的下一代API使用XML格式定义X协议(protocol),并使用脚本生成特定语言绑定(bind)。它在概念上与SWIG类似,只是它描述的不是CAPI,而是X协议(protocol)。目前,C和Python存在绑定(bind)。理论上,Ruby端口只是编写一个从XML协议(protocol)定义语言到Ruby的翻译器的问题。生

  10. ruby - 在没有基准或时间的情况下用 Ruby 测量用户时间或系统时间 - 2

    因为我现在正在做一些时间测量,我想知道是否可以在不使用Benchmark类或命令行实用程序time的情况下测量用户时间或系统时间。使用Time类只显示挂钟时间,而不显示系统和用户时间,但是我正在寻找具有相同灵active的解决方案,例如time=TimeUtility.now#somecodeuser,system,real=TimeUtility.now-time原因是我有点不喜欢Benchmark,因为它不能只返回数字(编辑:我错了-它可以。请参阅下面的答案。)。当然,我可以解析输出,但感觉不对。*NIX系统的time实用程序也应该可以解决我的问题,但我想知道是否已经在Ruby中实

随机推荐