『Django』自带的后台


theme: smartblue

本文简介

点赞 + 关注 + 收藏 = 学会了

00.png

上一篇讲了 Django 操作 MySQL 的方法,讲了如何创建模型,如何对数据库做增删改查的操作。但每次修改数据都要写代码,多少有点麻烦。

有没有简单一点的方法呢?

有的有的,Django 其实自带了一个后台,是图形界面的,你可以在上面很方便的操作各种数据内容。

接下来就讲讲这个自带的后台怎么用。

配置后台路由地址

其实在创建 Django 项目时就已经帮我们把后台的路由地址配置好了。

如果你是跟着我前面的文章一步步做的话,可能后台路由会被删掉。没关系,补回去就好了。

打开项目的 urls.py 文件,找到 urlpatterns 这个变量,把后台路由补上。

```python

urls.py 项目的路由文件

from django.urls import path from blog.views import blogIndex

urlpatterns = [ # 省略了其他路由 # 下面这句才是配置后台的路由 path('admin/', admin.site.urls) ] ```

配置完成后,启动项目,在浏览器打开 http://127.0.0.1:8000/admin/ 就能看到后台的登录页面。

01.png

创建管理员账号

有登录页面,那就要有对应的账号才能登录上去。

所以我们要先创建一个超管账号。

打开终端,进入项目目录,输入以下这条命令创建超管账号。

python manage.py createsuperuser

然后终端会返回这一行信息给你,让你输入超管的用户名(账号)

Username (leave blank to use 'xxx'): admin

这里的'xxx'是我的计算机名字,你在冒号后面输入超管的账号即可。这里我输入的是 admin

输入完用户名后,它会继续让你输入邮箱。

Email address: 123@qq.com

输入完邮箱会让你输入2次密码。

Password: 
Password (again):

我这里输入的密码是 12345678,它很智能的提醒我的密码太常见了,但我输入 y ,坚持使用这么简单的密码。

This password is too common.
This password is entirely numeric.
Bypass password validation and create user anyway? [y/N]: y
Superuser created successfully.

看到 Superuser created successfully. 这句就表示账号创建成功了。

此时在浏览器打开 http://127.0.0.1:8000/admin/,账号输入 admin,密码输入 12345678 就能登录成功。

02.png

模型关联后台

我们前面都是使用代码的方式去操作数据库,不是那么方便。

Django 提供了一种方式,让我们将应用的模型和后台绑定,这样就可以在后台界面里直接操作数据了。

以上一篇文章创建的 account 应用为例。

account 应用中找到 admin.py 文件,写入以下代码。

```python

account/admin.py

from django.contrib import admin from account.models import User

class UserAdmin(admin.ModelAdmin): # 要展示的内容 list_display = ['username', 'email']

将 User 模型绑定到 UserAdmin

admin.site.register(User, UserAdmin) ```

这里需要先引入 adminUser,因为我们要将 account 应用的模型和后台关联起来。

创建一个名为 UserAdmin 的类,在里面写明 list_display = ['username', 'email'] ,意思是要在后台页面显示 usernameemail 这两个字段。

最后 admin.site.register(User, UserAdmin) 的意思是将 User 模型和后台绑定在一起。

运行项目,打开 http://127.0.0.1:8000/admin/ 并登录,就能看到刚刚绑定的模型了。

03.png

点击“用户表s”会看到在数据库中这个表的信息。

04.png

可以点击“Add”按钮在这个表里新增数据。

05.png

也可以对指定数据进行修改、删除操作。

06.png

后台页面修改完的数据会直接影响到数据库里的数据的。

以同样的方式,把 blog 应用的模型和后台关联起来。这里的操作和前面是相同的,我就不再重复讲解了。

```python

blog/admin.py

from django.contrib import admin from blog.models import Article

Register your models here.

class ArticleAdmin(admin.ModelAdmin): # 要展示的内容 list_display = ['id', 'title']

将 User 模型绑定到 UserAdmin

admin.site.register(Article, ArticleAdmin) ```

07.png

我们创建一篇文章看看。

点击“文章信息表s”旁边的Add按钮,然后填写好以下内容。

08.png

点击 SAVE 按钮后就将数据写入到数据库了,回到“文章信息表s”的列表页就能看到刚刚写入的数据。

09.png

如果不太清楚整个项目的内容,可以看回我整理的《Django专栏》。

后台的基础配置

在前面的操作中,细心的工友可能已经留意到一些问题,比如界面怎么是英文的?为什么表名后面会有个“s”?为什么创建文章的时候User这个字段可选的不是用户名,而是 User object(1)

接下来我们把这些问题一个个解决。

设置时区和语言

打开项目的 settings.py 文件,找到 LANGUAGE_CODE ,将它的值设置为 'zh-hans'。然后再找到 TIME_ZONE 将其设置为 Asia/Shanghai

```python

settings.py

语言

LANGUAGE_CODE = 'zh-hans'

时区

TIME_ZONE = 'Asia/Shanghai' ```

10.png

将栏目名改成中文

但此时 ACCOUNTBLOG 仍然是英文的,这里 Django 是不能直接将其翻译成中文,需要你给这两个应用配置别名。

11.png

配置的地方在各个应用自身的 apps.py 文件里,通过 verbose_name 变量来自定义栏目名称。

account 应用为例。

```python

account/apps.py

from django.apps import AppConfig

class AccountConfig(AppConfig): defaultautofield = 'django.db.models.BigAutoField' name = 'account' verbose_name = '用户管理' ```

blog 应用同理。

```python

blog/apps.py

from django.apps import AppConfig

class BlogConfig(AppConfig): defaultautofield = 'django.db.models.BigAutoField' name = 'blog' verbose_name = '文章管理' ```

此时再刷新页面就能看到栏目名称被改过来了。

12.png

删除复数形式

表名后面的“s“是 Django 自带的,要删掉这个“s”同样需要配置表的别名。

在各个应用的模型文件(models.py)里配置 Meta 信息的 verbose_name_plural

account 应用为例。

```python

account/models.py

from django.db import models

创建一个用户表

class User(models.Model): id = models.AutoField(primarykey=True) # 用户名 username = models.CharField('用户名', maxlength=30, null=True, blank=True, unique=True) # 密码 password = models.CharField('密码', max_length=30) # 邮箱 email = models.EmailField('邮箱', unique=True, null=True, blank=True)

class Meta:
    # 自定义表名
    db_table = 'user'
    # 表别名
    verbose_name = '用户表'
    verbose_name_plural = '用户表'

```

刷新一下页面就能看到“用户表”后面的“s”没了。

13.png

blog 同理。

展示外键字段

我们在添加文章的时候需要输入选择文章作者,文章表的作者是关联了用户表的。

在添加作者的时候页面直接展示了“User object”这种名字,用户数量一多的话我们就分不清谁是谁了。

14.png

我们应该将用户名展示出来。

这里我们先修改一下 blog 要展示的字段。

```python

blog/admin.py

from django.contrib import admin from blog.models import Article

获取作者

这个 obj 对象是用来接收 Article 实例

def get_author(obj): return obj.user.username

Register your models here.

class ArticleAdmin(admin.ModelAdmin): # 要展示的内容 # 此时这里就可以使用 getauthor 换取用户名了。这里不需要加上单引号,也不需要加上括号。 # django 在使用 listdisplay 时,会默认给方法传递一个参数。 listdisplay = ['id', getauthor, 'title', 'content']

getauthor.shortdescription = '作者'

将 User 模型绑定到 UserAdmin

admin.site.register(Article, ArticleAdmin) ```

通过 get_author 方法把外健关联的 username 字段展示出来了。

15.png

此时我们将能看到这篇文章的作者是谁了。但我们还需要在编辑页里的用户名展示出来才行。

此时需要修改 User 模型才行。

```python

account/models.py

from django.db import models

创建一个用户表

class User(models.Model): id = models.AutoField(primarykey=True) # 用户名 username = models.CharField('用户名', maxlength=30, null=True, blank=True, unique=True) # 密码 password = models.CharField('密码', max_length=30) # 邮箱 email = models.EmailField('邮箱', unique=True, null=True, blank=True)

class Meta:
    # 自定义表名
    db_table = 'user'
    # 表别名
    verbose_name = '用户表'
    verbose_name_plural = '用户表'

# 返回用户名
def __str__(self):
    return self.username

```

account/models.py 的最后加上 __str__ 方法,返回 username

此时在文章信息的编辑页里就能看到用户名了。

16.png

自定义编辑的跳转链接

在文章管理页面里,想要编辑文章只能点击“ID”这个字段才能跳转进编辑页。如果想通过点击其他字段也能跳转进编辑页就需要手动配置 blog/admin.py 了,比如我想点击“TITLE”也能跳进编辑页。

17.png

```python

blog/admin.py

省略部分代码

class ArticleAdmin(admin.ModelAdmin): # 要展示的内容 listdisplay = ['id', getauthor, 'title', 'content'] # 可跳转的字段 listdisplaylinks = ['id', 'title'] # 省略部分代码 ```

我在 ArticleAdmin 里添加了 list_display_links = ['id', 'title'],表示点击 idtitle 都可以跳转到编辑页。

只读属性

在编辑内容时,我们不希望某些字段可以修改。比如博客的id不能被修改。

可以在 blog/admin.py 中添加 readonly_fields 指定不能被修改的字段。

```python

blog/admin.py

省略部分代码

class ArticleAdmin(admin.ModelAdmin): # 只读属性 readonly_fields = ['id'] # 省略部分代码 ```

此时要编辑时,id字段的值就不能修改了。

18.png


以上就是本文的全部内容。下一篇我会介绍如何在前台页面加载数据库里的信息。

IMG_8982.GIF

点赞 + 关注 + 收藏 = 学会了

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

centos 安装ffmpeg

这个错误表明在你的 CentOS 系统的默认仓库中没有 ffmpeg 包。CentOS 的默认仓库通常不包含 ffmpeg,因为它涉及一些许可证问题。但是,你可以通过添加第三方仓库来安装 ffmpeg。 使用 EPEL 和 RPM Fusion 仓库 # 安装 EPEL 仓库 sudo yum install epel-…

苹果入局,AI手机或将实现“真智能”?

【潮汐商业评论/原创】 “AI应用智能手机不就是现在的AI手机。” 当被问到现阶段对AI手机的看法时,John如是说。“术业有专攻,那么多APP在做AI功能,下载用就是了,也用不着现在换个AI手机啊。” 对于AI手机,或许大多…

Windows中安装部署MinIo文件系统,在Spring Boot中引入MinIo依赖实现上传文件到MinIo文件系统中

minio安装部署可以看这篇教程&#xff1a;https://blog.csdn.net/qq_43108153/article/details/134016896 创建桶 将私有设置成公开 导入依赖 <!-- minio --> <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId>…

【正点原子K210连载】第二十一章 machine.UART类实验摘自【正点原子】DNK210使用指南-CanMV版指南

1&#xff09;实验平台&#xff1a;正点原子ATK-DNK210开发板 2&#xff09;平台购买地址https://detail.tmall.com/item.htm?id731866264428 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/docs/boards/xiaoxitongban 第二十一章 machine.…

Java中HashMap详解:hash原理、扩容机制、线程不安全及源码分析

前言 HashMap 是 Java 中常用的数据结构之一&#xff0c;用于存储键值对。在 HashMap 中&#xff0c;每个键都映射到一个唯一的值&#xff0c;可以通过键来快速访问对应的值&#xff0c;算法时间复杂度可以达到 O(1)。 HashMap 的实现原理是基于哈希表的&#xff0c;它的底层是…

禁用华为小米?微软中国免费送iPhone15

微软中国将禁用华为和小米手机&#xff0c;要求员工必须使用iPhone。如果还没有iPhone&#xff0c;公司直接免费送你全新的iPhone 15&#xff01; 、 这几天在微软热度最高的话题就是这个免费发iPhone&#xff0c;很多员工&#xff0c;收到公司的通知。因为&#xff0c;登录公司…

ITSS服务经理职责与认可情况分析

随着信息技术的高速发展和广泛应用&#xff0c;企业对信息技术管理和应用的需求日益凸显。 为满足这一迫切需求&#xff0c;对具备专业知识和技能的人才的需求也日益增长&#xff0c;他们负责管理和实施相关项目。 因此&#xff0c;ITSS服务项目经理证书应运而生&#xff0c;这…

提升Selenium在Chrome上的HTML5视频捕获效果的五个方法

在使用Selenium进行网页自动化测试时&#xff0c;捕获HTML5视频是一个常见的需求。然而&#xff0c;许多开发者发现&#xff0c;在使用Chrome浏览器时&#xff0c;视频捕获效果并不理想&#xff0c;经常出现视频背景为空白的问题。本文将概述五种方法&#xff0c;帮助提升Selen…

基于语义的法律问答系统

第一步&#xff0c;准备数据集 第二步&#xff0c;构建索引数据集&#xff0c;问答对数据集&#xff0c;训练数据集&#xff0c;召回评估数据集 第三步&#xff0c;构建dataloader,选择优化器训练模型&#xff0c;之后召回评估 第四步&#xff0c;模型动转静&#xff0c;之后…

eplan软件许可优化解决方案

Eplan软件介绍 Eplan是一款专业的电气设计软件&#xff0c;用于自动化工程和电气系统的设计与文档化。它由德国的Eplan Software & Service GmbH开发&#xff0c;并在全球范围内广泛应用于工程设计和电气工程领域。 Eplan软件提供了全面的工具和功能&#xff0c;以简化和优…

Vue3 引入腾讯地图 包含标注简易操作

1. 引入腾讯地图API JavaScript API | 腾讯位置服务 (qq.com) 首先在官网注册账号 并正确获取并配置key后 找到合适的引入方式 本文不涉及版本操作和附加库 据体引入参数参考如下图 具体以链接中官方参数为准标题 在项目根目录 index.html 中 写入如下代码 <!-- 引入腾…

微软的人工智能语音生成器在测试中达到与人类同等水平

微软公司开发了一种新的神经编解码语言模型 Vall-E&#xff0c;在自然度、语音鲁棒性和说话者相似性方面都超越了以前的成果。它是同类产品中第一个在两个流行基准测试中达到人类同等水平的产品&#xff0c;而且显然非常逼真&#xff0c;以至于微软不打算向公众开放。 VALL-E …

车载测试资料学习和CANoe工具实操车载项目(每日直播)

每日直播时间&#xff1a;&#xff08;直播方式&#xff1a;腾讯会议&#xff09; 周一到周五&#xff1a;20&#xff1a;00-23&#xff1a;00 周六与周日&#xff1a;9&#xff1a;00-17&#xff1a;00 向进腾讯会议学习的&#xff0c;可以关注我并后台留言 直播内容&#xff…

GPMC并口多通道AD采集案例,基于TI AM62x四核处理器平台!

GPMC并口简介 GPMC(General Purpose Memory Controller)是TI处理器特有的通用存储器控制器接口&#xff0c;是AM62x、AM64x、AM437x、AM335x、AM57x等处理器专用于与外部存储器设备的接口&#xff0c;如&#xff1a; (1)FPGA器件 (2)ADC器件 (3)SRAM内存 (4)NOR/NAND闪存 …

electron实现右键菜单保存图片功能

1.创建窗口&#xff0c;加载页面&#xff0c;代码如下&#xff1a; //打开窗口const {ipcMain, BrowserWindow} require("electron") const saveImage require("../ipcMain/saveImage") let win null; ipcMain.handle(on-open-event, (event, args) &g…

Airtest成功案例分享:KLab连续2年携Airtest私有云产品参加CEDEC大会!

一、KLab株式会社介绍 KLab株式会社是一家位于日本的移动游戏开发公司&#xff0c;成立于2000年。公司以开发和运营基于动漫和漫画IP的手机游戏而闻名&#xff0c;尤其是在音乐节奏游戏领域。KLab的一些知名作品包括《LoveLive!学园偶像祭》、《排球少年&#xff1a;新的征程》…

【unity笔记】常见问题收集

一 . Unity Build GI data 卡住问题 问题解决: 参考官方文档&#xff0c;GI(Global Illumination) data 指的是全局照明信息。 在Unity的Edit->Preference中&#xff0c;可以编辑GI缓存路径和分配GI缓存大小。 调出Window->Rendering->Lighting窗口&#xff0c;取消…

阿里云调整全球布局关停澳洲云服务器,澳洲服务器市场如何选择稳定可靠的云服务?

近日&#xff0c;阿里云宣布将关停澳大利亚地域的数据中心服务&#xff0c;这一决定引发了全球云计算行业的广泛关注。作为阿里云的重要海外市场之一&#xff0c;澳洲的数据中心下架对于当地的企业和个人用户来说无疑是一个不小的挑战。那么&#xff0c;在阿里云调整全球布局的…

vue vite+three在线编辑模型导入导出

文章目录 序一、1.0.0版本1.新增2.编辑3.导出4.导入 二、2.0.0版本1. 修复模型垂直方向放置时 模型会重合4. 修复了导出导入功能 现在是1:1导出导入5. 新增一个地面 视角看不到地下 设置了禁止编辑地面 地面设置为圆形6. 新增功能 可选择基本圆形 方形 圆柱形等模型以及可放置自…

判断非radio\checkbox 勾选框是否被勾选

1、通常如果是标准的勾选框我们可以使用使用isSelected()方法无法判断其勾选状态&#xff0c;如下代码&#xff1a; Boolean bldriver.findElement(By.xpath("//*[contains(class,el-icon-success)]")).isSelected(); 2、如图所示&#xff0c;该勾选框并不是一个…