56.Django的admin后台管理使用方法

news2025/1/12 2:45:33

准备

Django框架提供了一个自动化后台管理功能,对网站数据的后台维护,仅仅需要进行非常简单的配置和编写极少的代码即可实现。
首先创建一个Django项目admin_study,然后创建连接数据库,在数据库中创建好表数据库后,进行数据库的预备迁移和迁移。具体操作流程可以查看上一篇文章
如何进行项目搭建以及连接数据库

1. 配置

settings.py中:

INSTALLED_APPS = [
    'django.contrib.admin',
]

如果需要实现后台管理的中文显示,则修改以下配置:

LANGUAGE_CODE = 'zh-Hans'
USE_I18N = True

2、URL路由

​ urls.py中:

urlpatterns = [
    path('admin/', admin.site.urls),
]

3、创建Django后台管理员账户

​ 创建管理员账户之前,确保项目的数据库已经正确连接,并且已经将admin应用的模型进行了迁移

​ 另外,如果settings中配置了 AUTH_PASSWORD_VALIDATORS,那么会对用户名和密码进行对应的检测,譬如:不能太简单,不能是纯数字等
在这里插入图片描述
在这里插入图片描述

进入后台管理
在这里插入图片描述

4. 基本模型管理

4.1 建立模型

创建子应用

python manage.py startapp student_app

在子应用models中建立模型

from django.db import models

class Student(models.Model):
    sname = models.CharField(max_length=30)
    sage = models.IntegerField()
    # 返回数据,用于显示
    def __str__(self) -> str:
        return f'{self.sname, self.sage}'

配置子应用

INSTALLED_APPS = [
    'student_app',
]

数据库迁移

 python manage.py makemigrations
 python manage.py migrate

4.2 添加模型管理

注册模型(否则后台无法访问)在admin.py中

from django.contrib import admin

# Register your models here.
from .models import Student
admin.site.register(Student)

4.3 在浏览器中访问

再次启动服务
在这里插入图片描述

4.4 进一步完善显示

创建子应用

python manage.py startapp student_app2

配置参考方法4.1
在app中修改应用名称

from django.apps import AppConfig
class StudentApp2Config(AppConfig):
    default_auto_field = 'django.db.models.BigAutoField'
    name = 'student_app2'
    verbose_name = '学生子应用' # 修改应用名称

创建模型

from django.db import models
# Create your models here.
class Student(models.Model):
    sname = models.CharField(max_length=30, verbose_name='姓名')
    sage = models.IntegerField(verbose_name='年龄')

    class Meta:
        # verbose_name_plural: 复数形式
        # verbose_name 显示描述信息
        verbose_name_plural = verbose_name = '学生'
    
    def __str__(self) -> str:
        return f'{self.sname}, {self.sage}'

在这里插入图片描述

4.5 特殊下拉属性管理

创建子应用,配置方法参考4.1
模型创建

from django.db import models

# Create your models here.
class Student(models.Model):
    SEX_CHOICES=((1,'男'),(2,'女')) # 定义元组作为下拉框
    sname = models.CharField(max_length=20, verbose_name='姓名')
    sage = models.IntegerField(help_text='大于18', verbose_name='年龄')
    sex = models.IntegerField(choices=SEX_CHOICES, default=1, verbose_name='性别')
    # 增加 Meta类
    class Meta:
        verbose_name_plural = verbose_name = "学生"
    # 模型类的字符串化
    def __str__(self) -> str:
        return f'{self.sname}({self.pk})'

在这里插入图片描述

5、关系模型管理

5.1 建立模型

创建子应用——one_more_app
创建一对一和一对多模型

from django.db import models

class Place(models.Model):
    name = models.CharField(max_length=50, verbose_name='地名')
    address = models.CharField(max_length=80, verbose_name='门牌')

    def __str__(self):
        return f'{self.name}-{self.address}'

    class Meta:

        verbose_name_plural = verbose_name = '地址'

class Restaurant(models.Model):
    place = models.OneToOneField(
        Place,
        on_delete=models.CASCADE,
        primary_key=True,
        verbose_name='地址'
    )

    name = models.CharField(max_length=50, verbose_name='名字')
    # BooleanField 在数据库使用 tinyint 类型
    serves_hot_dogs = models.BooleanField(default=False, verbose_name='经营热狗')
    serves_pizza = models.BooleanField(default=False, verbose_name='经营披萨')

    def __str__(self):
        return self.name

    class Meta:

        verbose_name_plural = verbose_name = '餐馆'

class Waiter(models.Model):
    restaurant = models.ForeignKey(Restaurant, on_delete=models.CASCADE, verbose_name='餐馆')
    name = models.CharField(max_length=50, verbose_name='姓名')

    def __str__(self):
        return self.name

    class Meta:

        verbose_name_plural = verbose_name = '服务员'

在一对一模型中,添加完主表,关联表就采用下拉框的形式输入
在这里插入图片描述
采用布尔值,采用单选框的形式
在这里插入图片描述
后台管理多对多模型

from django.db import models

class SchoolClass(models.Model):
    name = models.CharField(max_length=20, verbose_name='班级名')

    class Meta:

        verbose_name_plural = verbose_name = '班级'

    def __str__(self):
        return self.name

class Teacher(models.Model):
    name = models.CharField(max_length=10, verbose_name='姓名')
    school_class = models.ManyToManyField(SchoolClass, verbose_name='班级')

    class Meta:

        verbose_name_plural = verbose_name = '老师'

    def __str__(self):
        return self.name

在这里插入图片描述
在这里插入图片描述

6.自定义模型管理类

6.1 自定义模型管理类的使用方法

之前使用的 admin.site.register(Student) 是用的 Django 默认的管理类,也可以自定义:
模型

from django.db import models

# Create your models here.
class Person(models.Model):
    pname = models.CharField(max_length=30, verbose_name='姓名')
    age = models.IntegerField(help_text='大于18', verbose_name='年龄')
    def __str__(self) -> str:
        return f'{self.pname}---{self.age}'
    class Meta:
        verbose_name_plural = verbose_name = '用户'

后台管理admin.py

from django.contrib import admin

# Register your models here.
from .models import Person
# 默认方式管理
# admin.site.register(Person)

# 自定义方式管理方法1:
# 定义管理的方法类
# class PersonAdmin(admin.ModelAdmin):
#     list_display = ['pname', 'age'] # 展示时的数据列表
#     ordering = ['-age'] # 排序方式
# # 给对应的模型类注册对应的方法
# admin.site.register(Person, PersonAdmin)

# 自定义方式管理方法2:
# 使用装饰器管理
@admin.register(Person)
class PersonAdmin(admin.ModelAdmin):
    list_display = ['pname', 'age'] # 展示时的数据列表
    ordering = ['-age'] # 排序方式


6.2自定义模型管理类属性

定义是否需要管理与是否必须填写字段

@admin.register(Person)
class PersonAdmin(admin.ModelAdmin):
    list_display = ['pname', 'age'] # 展示时的数据列表
    ordering = ['-age'] # 排序方式
    # 定义需要管理的字段,需要在admin中添加
    # fields = ('pname',)
    # 定义不需要管理的字段,不需要在admin中添加
    # exclude = ('age',)

class Person(models.Model):
    pname = models.CharField(max_length=30, verbose_name='姓名', null=True, blank=True)

优化多对多模型中的查询框
在这里插入图片描述

from django.contrib import admin

# Register your models here.
from .models import *
admin.site.register(SchoolClass)
# admin.site.register(Teacher)

@admin.register(Teacher)
class TeacherAdmin(admin.ModelAdmin):
    ordering = ('name',)
    filter_horizontal=('school_class', )# 修改普通选择框

7.增加额外批量操作

  1. 动作函数是单独的模块函数:
    在这里插入图片描述

方法1:函数方式添加

# 自定义批量处理函数
from django.db.models import F
def age_add_one(modeladmin,request,queryset):
    queryset.update(age=F('age')+1)
# 给自定义的方法添加表述信息(用于显示)
age_add_one.short_description = '批量给用户添加一岁'

# 自定义方式管理方法2:
# 使用装饰器管理
@admin.register(Person)
class PersonAdmin(admin.ModelAdmin):
    list_display = ['pname', 'age'] # 展示时的数据列表
    ordering = ['-age'] # 排序方式
    actions = [age_add_one]

方法2:定义到类中的方法

# 自定义方式管理方法2:
# 使用装饰器管理
@admin.register(Person)
class PersonAdmin(admin.ModelAdmin):
    list_display = ['pname', 'age'] # 展示时的数据列表
    ordering = ['-age'] # 排序方式
    from django.db.models import F
    def age_add_one(modeladmin,request,queryset):
        queryset.update(age=F('age')+1)
    # 给自定义的方法添加表述信息(用于显示)
    age_add_one.short_description = '批量给用户添加一岁'
    actions = [age_add_one]

8. 覆盖admin默认模板

​ 如果我们要在admin管理页面中,增加自己的功能,那么我们需要覆盖admin的默认模板,通过以下步骤实现:

8.1 admin允许覆盖的页面

  • app_index.html
  • change_form.html
  • change_list.html
  • delete_confirmation.html
  • object_history.html
  • popup_response.html

8.2 admin管理模板目录

​ django库下的 contrib/admin/templates/admin 目录,可以查看django自带的所有模板

8.3 自定义模板

​ 需要修改admin的哪个内置模板,则继承哪个模板,并且在其基础上进行修改,我们以app_index.html为例:

​ 原始模板是:

{% extends "admin/index.html" %}
{% load i18n %}

{% block bodyclass %}{{ block.super }} app-{{ app_label }}{% endblock %}

{% if not is_popup %}
{% block breadcrumbs %}
<div class="breadcrumbs">
<a href="{% url 'admin:index' %}">{% trans 'Home' %}</a>
&rsaquo;
{% for app in app_list %}
{{ app.name }}
{% endfor %}
</div>
{% endblock %}
{% endif %}

{% block sidebar %}{% endblock %}

8.4 建立对应模板

​ 在settings中配置的templates目录下,建立admin目录,并且在admin目录下,建立mysite目录(mysite是你的应用名,假设mysite是children,那么目录结构如下图)

在这里插入图片描述

{%extends "admin/app_index.html" %}
{% block sidebar %}
覆盖admin的app_index.html页面
{% endblock %}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/24845.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[附源码]java毕业设计小区物业管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

头歌-信息安全技术-用Python实现自己的区块链、支持以太坊的云笔记服务器端开发、编写并测试用于保存云笔记的智能合约、支持以太坊的云笔记小程序开发基础

头歌-信息安全技术-用Python实现自己的区块链、支持以太坊的云笔记服务器端开发、编写并测试用于保存云笔记的智能合约、支持以太坊的云笔记小程序开发基础一、用Python实现自己的区块链1、任务描述2、评测步骤(1)打开终端&#xff0c;输入两行代码即可评测通过二、支持以太坊的…

MySQL的高阶学习:索引、B+树

1.索引 索引是一种数据结构&#xff0c;如果没有索引&#xff0c;查找一个数据就需要从第一页开始全局检索直至找到需要的数据&#xff0c;有了索引可以先在目录中根据拼音查找到该数据所在的页数&#xff0c;因此通过索引可以大大减少了查询时间。 索引有两种存储类型&#xf…

金融科技赋能 互融云手机回租系统 实现资产全流程在线运营管理

在共享单车、充电宝等共享商业的兴起与成熟之后&#xff0c;“信用租赁”的模式悄然诞生&#xff0c;租房、租衣、租数码等已成常态。信用租赁系统的出现&#xff0c;带活了一大批租赁经济&#xff0c;尤其是手机行业。 伴随手机零售业的增长以及新品发布速度的提高&#xff0…

CY8C5888AXQ-LP096 CY8C5888AXI-LP096,IC MCU 32BIT

PSoC 5LP是一种真正的可编程嵌入式片上系统&#xff0c;集成了可配置的模拟和数字外设&#xff0c;内存和单芯片上的微控制器。PSoC 5LP架构通过以下方式提高性能&#xff1a; 32位Arm Cortex-M3核心加上DMA控制器和数字滤波处理器&#xff0c;最高可达80mhz 超低功率&#xff…

China SAFe Day 2022中国规模化敏捷大会圆满落幕!

China SAFe Day 202211月5日&#xff0c;2022 China SAFe Day暨第三届中国规模化敏捷大会在上海圆满落幕。 本届大会由Scrum中文网和SAI&#xff08;Scaled Agile Inc.&#xff09;联合主办&#xff0c;围绕 “敏捷企业与数字化变革” 这一主题展开&#xff0c;内容涵盖工业敏…

RSA加密原理与RSA公钥加密系统、数字签名

通过公钥加密系统&#xff0c;可以对传输于两个通信单位之间的消息进行加密&#xff0c;即使窃听者窃听到加密之后的消息&#xff0c;也不能对其破译。 1、RSA公钥加密原理 1.1 几个核心概念 公钥P与公钥函数P()密钥S与密钥函数S() 可以简单理解&#xff0c;一个公钥对应一个…

【数据结构】—— 单链表的增删改查

❤️一名热爱Java的大一学生&#xff0c;希望与各位大佬共同学习进步❤️ &#x1f9d1;个人主页&#xff1a;周小末天天开心 各位大佬的点赞&#x1f44d; 收藏⭐ 关注✅&#xff0c;是本人学习的最大动力 感谢&#xff01; &#x1f4d5;该篇文章收录专栏—数据结构 目录 方…

BUUCTF web之随便注

启动靶场访问如下&#xff0c;输入1&#xff0c;报错&#xff0c;可知是字符型注入&#xff0c;变量由单引号包裹 输入1 and 11 --&#xff0c;显示正常 先直接用sqlmap注入一下&#xff0c;显示存在注入&#xff0c;但是始终注入不出来数据库&#xff0c;“[ERROR] unable to …

Arnold渲染器适合什么样的电脑配置

Arnold 是 Solid Angle 和 Sony Pictures Imageworks 联合打造的顶级光线追踪 3D 渲染器。该程序是 Sony Imageworks 的主要渲染器&#xff0c;被全球 300 多家工作室使用。Arnold 6.0 及更高版本支持 GPU 渲染。Arnold GPU 的硬件建议是什么&#xff1f; 1. Arnold GPU 硬件推…

OpenKylin适配和虚拟打印机

最近在测国产OS客户端部分。首先客户端程序在CentOS全部使用没毛病&#xff0c;但是CentOS桌面体验比较差。然后就试了UOS&#xff0c;在UOS上测试到打印这块花了很多时间&#xff0c;碰到问题是CUPS有反应&#xff0c;但是没生成PDF文件&#xff0c;各种试了好久没解决。就寻思…

Android:单Activity多Fragment,Navigation实现Fragment跳转,Fragment之间通过ViewModel共享数据

单Activity多Fragment&#xff0c;Navigation实现Fragment跳转&#xff0c;Fragment之间通过ViewModel共享数据1、MainActivity2、HomeFragment, DetailFragment2.1、HomeFragment2.2、DetailFragment3、MyViewModel参考1、MainActivity 1、activity_main.xml <?xml vers…

ovs-vswitchd的启动分析

ovs-vswitchd的启动分析&#xff08;无修改源码&#xff09; &#xff08;一&#xff09;主要数据结构和概念了解 1.概念 在 OVS 中, 有几个非常重要的概念&#xff1a; Bridge: Bridge 代表一个以太网交换机&#xff08;Switch&#xff09;&#xff0c;一个主机中可以创建一…

Metabase学习教程:提问-4

Metabase中的表连接 如何在简单和自定义问题中使用查询编辑器连接Metabase中的表。 当涉及到分析数据时&#xff0c;必须要使用连接是一个事实&#xff0c;在Metabase&#xff0c;我们试图使您的问题的答案尽可能简单&#xff0c;即使这需要一些更复杂的策略。在本文中&#…

Spring中拦截器重复注册的问题排查

注册器JpushInterceptor 功能&#xff1a;新版的Java推送服务&#xff0c;将部分请求转发到老版node 查看日志发现拦截器日志重复 同一个链路&#xff0c;发现&#xff0c;经过同一个拦截器两次 debug发现注册器重复注册 第一个通过registry.addInterceptor注册 是通过We…

组合数学总结

文章目录三、递推关系3.1 常系数线性递推关系特征根法1.齐次递推关系2.非齐次方程母函数方法三、递推关系 3.1 常系数线性递推关系 k阶齐次递推关系&#xff1a;anc1an−1c2an−2...ckan−k0&#xff0c;ck≠0(3.1.1)k阶非齐次递推关系&#xff1a;anc1an−1c2an−2...ckan−kf…

SpringCloud微服务(四)——Nacos服务注册和配置中心

SpringCloud Alibaba Nacos服务注册和配置中心 Spring Cloud Netflix Projects Entering Mainterance Mode SpringCloud Alibaba&#xff1a; 服务限流降级&#xff1a;默认支持 WebServlet、WebFlux, OpenFeign、RestTemplate、Spring Cloud Gateway, Zuul, Dubbo 和 Rocke…

在 UltraEdit v15.00 及更高版本中添加用于语法高亮的 wordfile丨使用教程

UltraEdit原生支持开箱即用的最常用编程和标记语言的语法突出显示。但是&#xff0c;我们也有数百个其他语言的单词文件&#xff0c;而且很容易找到并添加您需要的语言&#xff01;重要提示&#xff1a;此电源提示适用于运行 UltraEdit v15.00或 UEStudio v09.10及更高版本的用…

rosjava零散

笔者之前想在非ros环境下使用通信&#xff0c;了解到rosjava可以实现&#xff0c;不过后来换成了rosbridge&#xff0c;也搜集了一些rosjava的资料&#xff0c;放在这里供参考(没时间整理了&#xff0c;格式较乱请见谅) 安装方式&#xff1a;sudo apt-get install ros-indigo-…

Blind Backdoors in Deep Learning Models 论文笔记

#论文笔记# 1. 论文信息 论文名称Blind Backdoors in Deep Learning Models作者Eugene Bagdasaryan Vitaly Shmatikov Cornell Tech出版社USENIX Security Symposium 2021 &#xff08;网安A类会议&#xff09;pdf论文主页 本地PDF代码pytoch_Backdoors_101 2. introduction …