首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
03 | 初识Django:Django适合做什么?
04 | 用2个命令创建一个包含用户管理功能的后台
05 | 职位管理系统:开始Django之旅 :创建一个可以管理职位的后台
06 | 职位管理系统:产品体验优化:快速迭代完善应用
07 | 职位管理系统:添加自定义页面:让匿名用户可以浏览职位列表页
08 | 职位管理系统:添加自定义页面:让匿名用户可以查看职位详情
09 | 招聘评估系统:产品背景、迭代思维与MVP产品规划
10 | 招聘评估系统:唯快不破:在产品中使用产品迭代思维
11 | 招聘评估系统:数据建模 & 企业级数据库设计原则
12 | 招聘评估系统:创建应用和模型,分组展示页面内容
13 | 招聘评估系统:如何批量从Excel文件导入候选人数据
14 | 招聘评估系统:产品体验优化:候选人列表筛选和查询
15 | 招聘评估系统:省去单独的账号管理工作:企业域账号集成
16 | 招聘评估系统:批量设置面试官:面试官的导入、授权
17 | 招聘评估系统:产品新需求 :如何导出候选人的数据到CSV
18 | 招聘评估系统:如何记录日志方便排查问题
19 | 招聘评估系统:生产环境与开发环境配置分离
20 | 招聘评估系统:产品细节完善
21 | 简历投递和面试流程:定制更美观的主题
22 | 简历投递和面试流程:定制面试官权限
23 | 简历投递和面试流程:钉钉群消息集成&通知一面面试官
24 | 简历投递和面试流程:允许候选人注册登录: 集成Registration
25 | 简历投递和面试流程:候选人简历存储:创建简历Model
26 | 简历投递和面试流程:让候选人可以在线投递简历
27 | 简历投递和面试流程:使用Bootstrap来定制页面样式
28 | 简历投递和面试流程:简历评估&安排一面面试官
29 | 简历投递和面试流程:定制列表字段,查看简历详情
30 | 简历投递和面试流程:为已有系统数据库生成管理后台
31 | Django的中间件(Middleware)
32 | 创建请求日志、性能日志记录中间件
33 | 在Django中支持多语言
34 | 错误和异常日志上报:Sentry集成
35 | 错误和异常日志上报:捕获异常上报到Sentry并发送钉钉群通知
36 | Django安全防护:防止XSS跨站脚本攻击
37 | Django安全防护:CSRF跨站请求伪造和SQL注入攻击
38 | Django Rest Framework开放API
39 | 在Django中使用缓存&Redis的使用
40 | Django与Celery 集成:Celery的使用
41 | Django与Celery集成:异步任务
42 | Django与Celery集成:定时任务
43 | 文件和图片上传功能
44 | 实践中的问题:多数据库路由
45 | Django之美:大数据量的关联外键 (autocomplete_fields)
46 | Django之美:20行代码实现只读站点ReadOnlyAdmin
47| Django之美:10行代码自动注册所有Model到Admin管理后台
48 | Django之美:Signals信号及其使用场景
49 | Django之美:CSR架构总结之Celery
50 | Django之美:Sentry&Django Rest Framework
51 | Django之美:Django的常用插件
52 | 生产环境要注意哪些事项:生产环境的应用部署
53 | 应用水平扩展:使用负载均衡
54 | 让网站访问更快:使用CDN加速
55 | 让故障在第一时间被感知到:接入监控告警
56 | 生产环境中的安全:生产环境的安全设计
57 | 生产环境中的安全:应用安全
58 | 生产环境中的安全:架构安全
59 | 生产环境中的安全:数据安全
60 | 生产环境中的安全:密码安全与业务安全
61 | 云环境中的部署:Docker容器的基础用法
62 | 云环境中的部署:如何像分发集装箱一样发布应用
63 | 云环境中的部署:开发环境的容器化&构建小镜像
64 | 云环境中的部署:什么时候需要容器编排
65 | 云环境中的部署:阿里云上搭建Kubernetes集群
66 | 云环境中的部署:管理监控容器中的Django应用
67 | 云环境中的部署:应用日志收集与查询
68 | 云环境中的持续集成:CI/CD的工作流程
69 | 云环境中的持续集成:CI/CD的基本使用
当前位置:
首页>>
技术小册>>
Django快速开发实战
小册名称:Django快速开发实战
### 04 | 用2个命令创建一个包含用户管理功能的后台 在Django框架中,快速搭建一个包含用户管理功能的后台是项目开发的常见需求。用户管理不仅涉及用户注册、登录、注销等基本操作,还包括用户信息的查看、编辑、删除等高级功能。幸运的是,Django通过其强大的内置功能,特别是`django.contrib.admin`模块,使得这一过程变得异常简单。在本章中,我们将通过两个简单的命令,快速搭建一个包含完整用户管理功能的后台系统。 #### 准备工作 在开始之前,请确保你已经安装了Django,并且创建了一个新的Django项目。如果你还没有这样做,可以按照以下步骤进行: 1. **安装Django**(如果你还没有安装的话): ```bash pip install django ``` 2. **创建新的Django项目**: ```bash django-admin startproject myproject cd myproject ``` 3. **创建一个应用**(虽然对于使用`django.contrib.admin`来说不是必需的,但通常我们会为项目创建至少一个应用): ```bash python manage.py startapp myapp ``` 注意:虽然本章节主要聚焦于使用`django.contrib.admin`,但创建应用是一个好习惯,因为它允许你组织和管理项目的不同部分。 #### 第一步:启用`django.contrib.admin` Django的`admin`站点是一个功能强大的内容管理工具,它自动读取你的模型(models)并为你提供一个界面来添加、修改和删除数据库中的对象。为了使用它,你首先需要确保你的项目已经启用了`django.contrib.admin`。 1. **编辑`settings.py`文件**: 在项目的`settings.py`文件中,找到`INSTALLED_APPS`列表,并确保`django.contrib.admin`、`django.contrib.auth`(用户认证系统)、`django.contrib.contenttypes`(内容类型框架,用于权限和通用关系)和`django.contrib.sessions`(会话框架)都被包含在内。这些应用是`django.contrib.admin`正常工作的基础。 ```python INSTALLED_APPS = [ ... 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', ... ] ``` 2. **配置数据库**(如果尚未配置): `django.contrib.admin`需要数据库来存储用户信息和模型数据。确保你的`settings.py`文件中配置了数据库(通常是SQLite、PostgreSQL、MySQL等)。 ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': BASE_DIR / 'db.sqlite3', } } ``` #### 第二步:创建超级用户 在Django的`admin`站点中,你需要至少一个超级用户来登录并管理后台。使用Django的`createsuperuser`命令可以方便地创建这样的用户。 1. **创建超级用户**: 在项目根目录下(即包含`manage.py`的目录),运行以下命令: ```bash python manage.py createsuperuser ``` 按照提示输入用户名、电子邮件地址和密码。这个用户将拥有访问Django admin站点的所有权限。 #### 第三步:注册模型到admin站点(虽然不是通过命令,但很重要) 虽然这一步不直接通过命令完成,但它是使你的模型在admin站点中可用的关键步骤。Django不会自动将你的模型显示在admin站点中;你需要显式地注册它们。 1. **编辑`admin.py`文件**: 在你的应用(比如`myapp`)目录下,找到或创建一个名为`admin.py`的文件。然后,使用`admin.site.register()`函数来注册你的模型。 假设你有一个名为`MyModel`的模型,你可以这样注册它: ```python from django.contrib import admin from .models import MyModel admin.site.register(MyModel) ``` 注意:如果你还没有定义任何模型,Django的`User`模型(来自`django.contrib.auth`)已经默认注册到了admin站点,因此你可以直接通过admin站点管理用户。 #### 第四步:运行开发服务器并访问admin站点 现在,一切准备就绪,你可以启动Django的开发服务器,并通过浏览器访问admin站点来查看和管理用户。 1. **运行开发服务器**: 在项目根目录下,运行以下命令来启动开发服务器: ```bash python manage.py runserver ``` 2. **访问admin站点**: 打开浏览器,访问`http://127.0.0.1:8000/admin/`。使用你之前创建的超级用户凭据登录。 登录后,你将看到Django admin站点的仪表盘,其中列出了所有已注册的模型(包括用户模型)。你可以通过点击“用户”或“认证和授权”下的“用户”来管理用户,包括查看、编辑、添加和删除用户。 #### 总结 通过简单的两个命令(`django-admin startproject`和`python manage.py createsuperuser`,虽然注册模型到admin站点不是通过命令完成的,但它是流程中的关键一步),我们成功搭建了一个包含完整用户管理功能的Django后台。Django的`admin`站点是一个强大的工具,它极大地简化了数据库管理和内容编辑的工作。随着项目的深入,你还可以自定义admin站点的界面和行为,以满足更具体的需求。
上一篇:
03 | 初识Django:Django适合做什么?
下一篇:
05 | 职位管理系统:开始Django之旅 :创建一个可以管理职位的后台
该分类下的相关小册推荐:
Django零基础入门
Django框架入门指南