记录一下自己的学习过程,顺便也让大家学习一下比起官网文档更加通俗易懂
1 Django是什么
Django 是使用 Python 语言开发的一款免费而且开源的 Web 应用框架。
由于 Python 语言的跨平台性,所以 Django 同样支持 Windows、Linux 和 Mac 系统。
在 Python 语言炽手可热的当下,Django 也迅速的崛起,在 Web 开发领域占有一席之地。
基于 Python 开发的框架除了 Django 外,还有可以实现快速建站 Flask 和支持高并发处理的 Tornado ,而 Django 是最有代表性的一位,它们三者是当前最流行的 Python Web 框架。
2 Django的由来
Django 最初是被开发用来管理劳伦斯集团旗下一些以新闻内容为主的网站。
2003 年,Lawerence Journal-World 报社的 Web 开发者艾德里安和威利森开始用 Python 语言去开发应用。新闻界的快节奏使他们必须提高产品的开发速度,于是他们两个人想办法构建出了节省开发时间的框架,这个框架将能复用的组件或者模块放在一起,使开发者不必重复的工作,这是 Django 诞生的根本原因。
后来他们所在的开发小组决定将这个框架发布成一个开源软件。经过发展和时间的积累,Django 有了数以万计用户和贡献者,现在 Django 成为了 Web 开发者中最流行的框架。
总之,Python 的诞生是为了减少重复性工作,节省开发者时间,让开发者把精力投入到关键的开发环节中。
下图是Django的标志:
通过上面的介绍,可以给出 Web 框架的概念:
它是一套组件,提供通用的设计模式,能够最大程度地降低开发 Web 站点开发的难度,Django 的设计目标就是使复杂的工作变得简单。
3 Django的命名
Django 命名由来官方网站只给出了一句话:
css
To this day, he's considered one of the best guitarists of all time, Listen to his music. You'll like it.
Django 是以一个名叫 Django Reinhardt 吉他手的的名字来命名的。因为程序员的世界不能缺少音乐,开发者在他的音乐中得到灵感,为了感谢纪念这位吉他手,所以 Django 的名字也由此诞生!
Django 的发音也非常有趣,大写字母 D 不发音,正确的发音是"栈go",作为程序员不要读错哦。
4 Django的版本发布
Django 遵守 BSD(即伯克利软件发行)版权。
初次发布于 2005 年 7 月,并于 2008 年 9 月发行第一正式版本 1.0。
从正式版 1.0 之后,Django 的版本发布过程如下:
-
功能版
- 版本号定义为 A.B、A.B+1 等,大概每 8 个月发布一次,每个版本都有所改进。最新的 Django 版本是 Django 3.0 于 2020 年发布。
-
补丁版
- 主要用来修复 bug 或者安全问题,版本号为 A.B.C 或者 A.B.C+1。
-
LTS版
- LTS 也即长期支持版本,官方会长期提供支持和安全更新,时长至少三年,所以我们建议安装和使用 LTS 版本。
一些 Django 版本会被指定为 LTS,例如 1.11 LTS。值得大家注意的是,Django 最后一个支持 Python 2.7 的版本是 1.11 LTS,最新的 LTS 版本是 2.2 LTS。
官方网站提供 Django 版本的下载,同时也提供了完善的在线文档,地址是:
5 Django框架的特点
相对于 Python 的其他 Web 框架,Django 的功能是最完整的,Django 定义了服务发布、路由映射、模板编程、数据处理的一整套功能。
Django的主要特点如下:
- 完善的文档:经过多年的发展和完善,Django 官方提供了完善的在线文档,为开发者解决问题提供支持。
- 集成 ORM 组件:Django 的 Model 层自带数据库 ORM 组件,为操作不同类型的数据库提供了统一的方式。
- URL 映射技术:Django 使用正则表达式管理URL映射,因此给开发者带来了极高的灵活性。
- 后台管理系统:开发者只需通过简单的几行配置和代码就可以实现完整的后台数据管理Web控制台。
- 错误信息提示:在开发调试过程中如果出现异常,Django 可以提供完整的错误信息帮助开发者定位问题。
6 Django的设计模式
本节我们介绍 Django 的设计模式,也就是 MTV。
在 Web 开发领域还有另外一个非常著名的设计模式------MVC,它和 MTV 又有什么区别呢?
MVC设计模式与MTV设计模式是本节的重点
6.1 MVC设计模式
我们先对 MVC 设计模式进行介绍,它是 Web 设计模式的经典之作,MTV 模式也是在它的基础上衍生而来。
MVC 是 Model-View-Controller 的缩写,其中每个单词都有其不同的含义:
- Modle 代表数据存储层,是对数据表的定义和数据的增删改查;
- View 代表视图层,是系统前端显示部分,它负责显示什么和如何进行显示;
- Controller 代表控制层,负责根据从 View 层输入的指令来检索 Model 层的数据,并在该层编写代码产生结果并输出。
MVC设计模式示意图如下: MVC 设计模式的请求与响应过程描述如下:
- 用户通过浏览器向服务器发起 request 请求,Controller 接受请求后,同时向 Model 和 View 发送指令
- Mole 根据指令与数据库交互并选择相应业务数据,然后将数据发送给 Controller
- View 接收到 Controller 的指令后,加载用户请求的页面,并将此页面发送给 Controller
- Controller 接收到 Model 和 View 的数据后,将它们组织成响应格式发送给浏览器,浏览器通过解析后把页面展示出来
MVC 的 3 层之间紧密相连,但又相互独立,每一层的修改都不会影响其它层,每一层都提供了各自独立的接口供其它层调用,MVC 的设计模式降低了代码之间的耦合性(即关联性),增加了模块的可重用性,这就是 MVC 的设计模式。
6.2 MTV设计模式
那么 Django 的 MTV 又是怎么回事呢?下面讲解 Django 的设计模式。
Django 借鉴了经典的 MVC 模式,它也将交互的过程分为了 3 个层次,也就是 MTV 设计模式:
- Model:数据存储层,处理所有数据相关的业务,和数据库进行交互,并提供数据的增删改查
- Template:模板层(也叫表现层)具体来处理页面的显示
- View:业务逻辑层,处理具体的业务逻辑,它的作用是连通Model 层和 Template
MTV 设计模式示意图如下:
我们按照 MVC 的设计模式对 MTV 进行分析,MTV 设计模式中,用 View 层取代了 Controller 层的位置,用 Template 层取代了原来 View 层的位置。
初次接触 Django 的设计模式的人,可能会对 Template 层产生疑问,其实 Template 英文的含义就是"模板"的意思,你可以简单理解成,它是一个 HTML 页面 ,HTML 页面的渲染在视图层完成。
MTV 设计模式的请求与响应过程描述如下:
- 用户通过浏览器对服务器发起 request 请求,服务器接收请求后,通过 View 的业务逻辑层进行分析,同时向 Model 层和 Template 层发送指令;
- Mole 层与数据库进行交互,将数据返回给 View 层;
- Template 层接收到指令后,调用相应的模板,并返回给 View 层;
- View 层接收到模板与数据后,首先对模板进行渲染(即将相应的数据赋值给模板),然后组织成响应格式返回给浏览器,浏览器进行解析后并最终呈现给用户。
通过以上两种设计模式的比较, 我们可以得出 MTV 是 MVC 的一种细化,将原来 MVC 中的 V 层拿出来进行分离,视图的显示与如何显示交给 Template 层,而 View 层更专注于实现业务逻辑。其实在 Django 是有 Controller 层的,只不过它由框架本身来实现,所以我们不用关心它。Django 更关注于M、T 和 V。
7 Django安装与配置
在cmd命令行执行如下命令进行在线安装,安装时可以指定版本号:
ini
pip install django==3.2
推荐使用国内的清华镜像源:
ini
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple django==3.2
检查是否安装成功:
通过 CMD 命令行中进入 Python 交互解释器,用以下方式检查 Django 是否安装成功,若能成功返回 Django 版本号,则说明安装成功:
arduino
import django
django.get_version()
8 Django创建第一个项目
本节我们将学习如何创建 Django 项目以及 Django 项目的初始化,我们将创建一个名为 BookStore 的 Django 项目,用此项目来讲解 Django 框架的部分知识,通过这个项目我们将一起打开 Django 世界的大门。
8.1 第一个项目Bookstore
我们创建一个名为Book的文件夹,用它来承载Bookstore项目。
- 方式一:
在CMD命令行使用cd命令进入新建的Book文件夹,然后使用如下命令创建BookStore项目:
django-admin startproject Bookstore
startproject 是 django-admin 的子命令,它是专门用来创建 Django 项目的。
- 方式二(推荐):
在pycharm里面创建django项目:
- 第一步:
- 第二步:
创建完成后如图所示:
8.2 Django项目配置文件
二级子目录 BookStore 下的文件称为 Django 项目的配置文件, 它们在创建项目的时候自动生成。下面我们对上述涉及到的文件进行详细的说明:
-
manage.py
文件一级子目录中的 manage.py 文件是管理 Django 项目的重要命令行工具,它主要用于启动项目、创建应用和完成数据库的迁移等。
-
__init__.py
文件二级子目录中的
__init__.py
文件用于标识当前所在的目录是一个 Python 包,如果在此文件中,通过 import 导入其他方法或者包会被 Django 自动识别。 -
settings.py
文件settings.py 文件是 Django 项目的重要配置文件。项目启动时,settings.py 配置文件会被自动调用,而它定义的一些全局为 Django 运行提供参数,在此配置文件中也可以自定义一些变量,用于全局作用域的数据传递。
-
urls.py
文件url.py 文件用于记录 Django 项目的 URL 映射关系,它属于项目的基础路由配置文件,路由系统就是在这个文件中完成相应配置的,项目中的动态路径必须先经过该文件匹配,才能实现 Web 站点上资源的访问功能。
-
wsgi.py
文件wsgi.py 是 WSGI(Web Server Gateway Interface)服务器程序的入口文件,主要用于启动应用程序。它遵守 WSGI 协议并负责网络通讯部分的实现,只有在项目部署的时候才会用到它。
9 如何启动Django项目
我们使用 django-admin 命令成功创建项目后,我们要如何启动这个项目呢?本节的学习目标是能够通过本地回送地址 127.0.0.1 成功访问 BookStore 项目。
9.1 启动项目实现访问
-
方法一:
在 CMD 命令行工具中,执行
cd
命令进入 Book/BookStore 目录下,我们知道在 BookStore 子目录下有一个 manage.py 文件,而这个文件的主要作用之一就是用来启动项目的,所以必须和 manage.py 文件处于同一个路径下才可以执行启动命令,启动项目的命令如下所示:python manage.py runserver
-
方法二:
在pycharm的Terminal中输入以下命令:
在浏览器地址栏输入 http://127.0.0.1:8000 进行访问,如下图所示:
当你在地址栏回车的一瞬间,若出现了如图所示的界面后,那么恭喜你,表示项目的骨架已经搭建完成了。
其实你会发现我们只是用了一个启动命令,就实现一个站点的访问功能,这就是 Django 框架的优势所在,Django 框架依靠创建项目时生成的配置文件,从而构建了自身功能的完整性。
9.2 启动项目命令介绍
我们使用如下命令启动了项目:
python manage.py runserver
Django的默认启动端口是8000,当然也可以选定其他端口来启用。
比如,你想在你的计算机上启动多个 Django 项目,那么就需要多个端口启动不同的项目,否则就会出现端口重用的问题,那么如何通过指定端口号启动项目呢?我们可以使用如下命令格式:
yaml
python manage.py runserver 7000
上面的命令表示的是以 7000 端口启动项目。
10 settings.py配置文件详解
settings.py 配置文件,它是 Django 框架的重要配置文件,它定义的一些全局变量用来给 Django 框架传递参数,我们还可以根据自己的实际需求来修改这个文件从而实现某些特定的要求。下面我们对这个配置文件进行详细介绍,了解这个配置文件,是迈进 Django 世界的重要一步。
首先使用 Pycharm 打开 BookStore 项目,注意此时的根目录是一级子目录 BookStore,而不是 Book 目录,如图所示:
10.1 settings.py文件介绍
下面对 settings.py 配置文件涉及到的知识点进行依次讲解:
-
BASE_DIR
-
它用于绑定当前项目 BookStore 所在的绝对路径,项目中的所有的文件都需要依赖此路径,绑定路径的方法如下:
scssBASE_DIR = Path(__file__).resolve().parent.parent
__file__
是python的语法,显示当前文件的位置。
-
-
SECRET_KEY
- 这个变量的本质是一个加密的,它一般配合加密算法 Hash、MD5 一起使用。例如用户密码的加密或者建立会话时用到的 sessionid 都需要用到 SECRET_KEY 。在实际的开发工作中,一般将它保存在系统的环境变量中以确保加密盐的安全。
-
DEBUG
用于配置 Django 项目的启用模式,有两种取值方式:
- DEBUG = True用于在开发环境中使用,属于调试模式,在项目的运行过程中会暴露一些错误信息以方便调试。
- DEBUG = False用于线上环境,表示不启用调试模式。
-
INSTALLED_APPS
这个参数是指当前项目中用来安装的应用(APP)的列表,Django 把默认自带的应用放在这个列表里,比如 Admin 后台应用、Auth 用户管理系统等。
我们可以根据自己的项目需求对其进行增加或删除,比如公司要单独开发一个后台管理系统,就可以把第一项 admin 注释掉。开发时自己编写的应用都必须在这个变量表中进行注册才能生效。所以这个列表需要经常的改动。
iniINSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', ]
-
MIDDLEWARE
它用于注册中间件,Django 默认加载了一些中间件。例如,用于处理会话的 SessionMiddleware 等,同样我们可以对这些中间件进行添加或者注释。
-
ROOT_URLCONF
iniROOT_URLCONF = 'Bookstore.urls'
它指定了当前项目的根 URL,是 Django 路由系统的入口。
-
TEMPLATES
它用于指定模板的配置信息,列表中每一元素都是一个字典。
-
WSGI_APPLICATION
项目部署时,Django 的内置服务器将使用的 WSGI 应用程序对象的完整 Python 路径。
-
DATABASES
它用于指定数据库配置信息,这里默认配置的是 Django 自带的 sqllite3 数据库。Django 支持多种数据库,在这个字典变量中更改数据库配置。在后续章节我们将对 Mysql 数据库配置进行讲解。
-
AUTH_PASSWORD_VALIDATORS
这是一个支持插拔的密码验证器,且可以一次性配置多个,Django 通过这些内置组件来避免用户设置的密码等级不足的问题。
-
LANGUAGE_CODE和TIME_ZONE
分别代表语言配置项和当前服务端时区的配置项,我们常用的配置如下所示:
- LANGUAGE_CODE 取值是英文:'en-us'或者中文:'zh-Hans';
- TIME_ZONE 取值是世界时区 'UTC' 或中国时区 'Asia/Shanghai'。
-
USE_I18N和USE_L10N
项目开发完成后,可以选择向不同国家的用户提供服务,那么就需要支持国际化和本地化。USE_I18N 和 USE_L10N 这两个变量值表示是否需要开启国际化和本地化功能。默认开启的状态。
提示:
USE_I18N = True 与 USE_L10N = True 其的 I18N 指的是国际化英文缩写,L10N 指的是本地化英文缩写。
-
USE_TZ = TRUE
它指对时区的处理方式,当设置为 True 的时候,存储到数据库的时间是世界时间 'UTC'。
-
STATIC_URL = '/static/'
它指的是静态资源的存放位置,静态资源包括 CSS、JS、Images。比如我们要在项目中添加一些图片,通常这些静态图片被存放在新建的 static 目录下,这样就实现了通过 STATIC_URL= '/static/' 路径对静态资源的访问。
以上就是对于 settings.py 配置文件的详细介绍。
10.2 如何配置setting.py文件
在开发的过程中,为了使 settings.py 适用项目,都要对这个默认配置文件进行相应的修改,那么我们应该如何修改呢,有哪几个重要的步骤呢?下面总结了配置文件的一些通用修改项,让我们一起来看看。
10.2.1 修改语言与时区
在项目中设置语言、时区是必不可少的。
打开 settings.py 文件,在文件的末尾部分找到相应的变量进行配置,如下所示:
ini
# 设置为中文模式
LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'
然后访问 127.0.0:8000 来验证,发现已经变成了中文模式,如图所示:
10.2.2 设置时区不敏感
当 USE_TZ 设置为 False 时,表示对时区不敏感,并且让数据库时间符合本地时区。
10.2.3 配置项目所需数据库
在 Django 项目中配置数据库是必不可少的,我们使用 MySQL 作为项目的数据库。
如果我们在Django中要连接mysql数据库,需要安装一个库(mysqlclient)
下面是 Django 默认配置的 sqlite3 数据库:
arduino
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': BASE_DIR / 'db.sqlite3',
}
}
在配置 MySQL 数据库之前,先进入 MySQL 命令行界面为项目建库,使用如下命令:
sql
CREATE DATABASE bookstoredb;
然后在 settings.py 文件中配置 MySQL 数据库,如下所示:
arduino
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'bookstoredb',
'USER': 'root',
'PASSWORD': '123456',
'HOST': '127.0.0.1',
'PORT': '3306',
}
}
注意:配置是根据自己的数据库的密码来,不要copy上述代码。
下面我们对上述DATABASES中的字典元素进行介绍:
- ENGINE:指定使用的数据库引擎
- NAME:指定项目所用的数据库名字
- USER:是 MySQL 用户名
- PASSWORD:指的是数据库的密码
- HOST:数据库服务器地址,这里是本地环境开发,所以使用本地回送地址 127.0.0.1
- PORT:MySQL 数据库的端口号,默认端口是 3306
10.2.4 学会阅读报错信息
Django 允许我们在项目运行过程中直接修改配置文件,但如果配置文件出错,那么错误信息将会输出到该项目对应的命令行。
如下所示:
说明没有安装mysqlclient,此时就需要安装一下。
以上就是对 settings.py 的文件的基本修改,当然 settings.py 还可以进行很多的配置,比如模板配置或者静态文件路径的配置,但是这些配置需要根据项目实际要求而定,在后续章节会对其进行介绍。