首页
技术小册
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快速开发实战
### 05 | 职位管理系统:开始Django之旅 —— 创建一个可以管理职位的后台 #### 引言 在本章中,我们将正式踏上Django快速开发实战的旅程,通过构建一个职位管理系统来深入理解Django框架的核心概念与强大功能。职位管理系统是一个典型的后台管理系统,旨在帮助组织或企业高效地管理其内部的职位信息,包括但不限于职位的创建、编辑、删除以及查询等功能。通过本章节的学习,你将学会如何从头开始搭建一个基于Django的Web应用,并熟悉Django的模型(Models)、视图(Views)、模板(Templates)和表单(Forms)等关键组件。 #### 准备工作 在开始之前,请确保你的开发环境中已经安装了Python和Django。如果尚未安装,可以通过Python的包管理工具pip来安装Django。打开你的命令行工具,执行以下命令: ```bash pip install django ``` 安装完成后,你可以通过运行`django-admin --version`来检查Django是否成功安装,并查看其版本。 #### 第一步:创建Django项目 首先,我们需要创建一个新的Django项目。在命令行中,切换到你想存放项目的目录,然后执行以下命令: ```bash django-admin startproject job_management_system ``` 这条命令会创建一个名为`job_management_system`的文件夹,其中包含了Django项目的基础结构。进入该文件夹: ```bash cd job_management_system ``` #### 第二步:创建应用 在Django中,应用(App)是项目的组件,负责处理特定的业务逻辑。对于我们的职位管理系统,我们可以创建一个名为`jobs`的应用。在项目根目录下(即包含`manage.py`的目录),执行以下命令: ```bash python manage.py startapp jobs ``` 这将在你的项目中创建一个名为`jobs`的新文件夹,里面包含了应用的基础文件。 #### 第三步:定义模型 模型是Django ORM(Object-Relational Mapping,对象关系映射)的核心,它允许我们以Python类的形式定义数据库中的表结构。在`jobs/models.py`文件中,我们定义职位的模型: ```python from django.db import models class Job(models.Model): title = models.CharField(max_length=100, verbose_name="职位名称") description = models.TextField(verbose_name="职位描述") salary = models.DecimalField(max_digits=10, decimal_places=2, verbose_name="薪资") created_at = models.DateTimeField(auto_now_add=True, verbose_name="创建时间") updated_at = models.DateTimeField(auto_now=True, verbose_name="更新时间") def __str__(self): return self.title class Meta: verbose_name = "职位" verbose_name_plural = "职位" ``` 上述代码定义了一个`Job`模型,包含职位名称、描述、薪资、创建时间和更新时间等字段。 #### 第四步:运行迁移 Django使用迁移(Migrations)来跟踪数据库结构的变更。为了将我们的模型同步到数据库中,我们需要先生成迁移文件,然后执行这些迁移。在项目根目录下,运行以下命令: ```bash python manage.py makemigrations python manage.py migrate ``` `makemigrations`命令会检测所有应用中的模型变更,并生成相应的迁移文件。`migrate`命令则会将这些迁移应用到数据库中,从而更新数据库结构。 #### 第五步:创建管理员用户 Django自带了一个强大的后台管理系统,称为Django Admin。为了访问它,我们需要先创建一个管理员用户。在项目根目录下运行: ```bash python manage.py createsuperuser ``` 按照提示输入用户名、邮箱和密码等信息,完成管理员用户的创建。 #### 第六步:注册模型到Admin 为了让我们的`Job`模型出现在Django Admin中,我们需要在`jobs/admin.py`文件中注册它。如果该文件不存在,你可以手动创建它。然后添加以下内容: ```python from django.contrib import admin from .models import Job admin.site.register(Job) ``` 现在,当你通过浏览器访问Django Admin(通常是`http://127.0.0.1:8000/admin/`)并登录后,你将看到`Job`模型已被列在可用模型列表中,并可以对其进行增删改查操作。 #### 第七步:自定义Admin界面 虽然Django Admin提供了基本的CRUD(Create, Read, Update, Delete)操作,但你可能想要自定义它的界面以满足特定的需求。例如,你可以通过修改`admin.py`中的注册代码来添加自定义的列表显示字段、过滤器或表单字段集。 ```python class JobAdmin(admin.ModelAdmin): list_display = ('title', 'salary', 'created_at') list_filter = ('created_at',) search_fields = ('title', 'description') admin.site.register(Job, JobAdmin) ``` 这段代码为`Job`模型定义了一个自定义的Admin类`JobAdmin`,并设置了列表显示字段、列表过滤器和搜索字段。 #### 第八步:运行开发服务器 最后,为了查看我们的职位管理系统在浏览器中的表现,可以启动Django的开发服务器: ```bash python manage.py runserver ``` 默认情况下,服务器会在`http://127.0.0.1:8000/`上运行。现在,你可以打开浏览器,访问Django Admin页面,开始管理你的职位信息了。 #### 结语 通过本章的学习,你已经成功创建了一个基于Django的职位管理系统后台。我们从头开始,逐步完成了Django项目的创建、应用的添加、模型的定义、迁移的执行、管理员用户的创建、模型的Admin注册以及界面的自定义。在这个过程中,你不仅掌握了Django的基本工作流程,还深入了解了Django的核心组件——模型、迁移、Admin等。接下来,你可以继续探索Django的其他高级功能,如视图、模板、表单等,以进一步完善你的职位管理系统。
上一篇:
04 | 用2个命令创建一个包含用户管理功能的后台
下一篇:
06 | 职位管理系统:产品体验优化:快速迭代完善应用
该分类下的相关小册推荐:
Django零基础入门
Django框架入门指南