🏘️🏘️个人简介:以山河作礼。
🎖️🎖️:Python领域新星创作者,CSDN实力新星认证,阿里云社区专家博主
🎁🎁:Web全栈开发专栏:《Web全栈开发》免费专栏,欢迎阅读!
🎁🎁:文章末尾扫描二维码可以加入粉丝交流群,不定期免费送书。
Django 是使用 Python 语言开发的一款免费而且开源的 Web 应用框架。
Django 最初是被开发用来管理劳伦斯集团旗下一些以新闻内容为主的网站。
2003 年,Lawerence Journal-World 报社的 Web 开发者艾德里安和威利森开始用 Python语言去开发应用。新闻界的快节奏使他们必须提高产品的开发速度,于是他们两个人想办法构建出了节省开发时间的框架,这个框架将能复用的组件或者模块放在一起,使开发者不必重复的工作,这是Django 诞生的根本原因。
后来他们所在的开发小组决定将这个框架发布成一个开源软件。经过发展和时间的积累,Django 有了数以万计用户和贡献者,现在 Django成为了 Web 开发者中最流行的框架。
下图是Django的标志:
通过上面的介绍,可以给出 Web 框架的概念:
它是一套组件,提供通用的设计模式,能够最大程度地降低开发 Web 站点开发的难度,Django 的设计目标就是使复杂的工作变得简单。
Django 是以一个名叫 Django Reinhardt(莱因哈特)吉他手的的名字来命名的。因为程序员的世界不能缺少音乐,开发者在他的音乐中得到灵感,为了感谢纪念这位吉他手,所以 Django的名字也由此诞生!
Django 的发音也非常有趣,大写字母 D 不发音,正确的发音是“栈go/姜戈”。
Django 初次发布于 2005 年 7 月,并于 2008 年 9 月发行第一正式版本 1.0。
以下是Django版本的一些主要发布历史:
相对于 Python 的其他 Web 框架,Django 的功能是最完整的,Django 定义了服务发布、路由映射、模板编程、数据处理的一整套功能。
Django的主要特点如下:
完善的文档:经过多年的发展和完善,Django 官方提供了完善的在线文档,为开发者解决问题提供支持。
集成 ORM(数据对象映射) 组件:Django 的 Model 层自带数据库 ORM 组件,为操作不同类型的数据库提供了统一的方式。
URL 映射技术:Django 使用正则表达式管理URL映射,因此给开发者带来了极高的灵活性。
后台管理系统:开发者只需通过简单的几行配置和代码就可以实现完整的后台数据管理Web控制台。
错误信息提示:在开发调试过程中如果出现异常,Django 可以提供完整的错误信息帮助开发者定位问题。
我们先对 MVC 设计模式进行介绍,它是 Web 设计模式的经典之作,MTV 模式也是在它的基础上衍生而来。
MVC是Model-View-Controller(模型-视图-控制器)的缩写,主要应用于Web应用开发。其中,Model表示数据和业务逻辑,View表示用户界面,Controller则负责处理用户请求、更新Model和View以及路由控制等一系列操作。通常来说,MVC会将Controller和View分开,使得系统的扩展性和可维护性更高。
MVC 是 Model-View-Controller 的缩写,其中每个单词都有其不同的含义:
MVC设计模式示意图如下:
MVC 设计模式的请求与响应过程描述如下:
MVC 的 3 层之间紧密相连,但又相互独立,每一层的修改都不会影响其它层,每一层都提供了各自独立的接口供其它层调用,MVC的设计模式降低了代码之间的耦合性(即关联性),增加了模块的可重用性,这就是 MVC 的设计模式。
Django 借鉴了经典的 MVC 模式,它也将交互的过程分为了 3 个层次,也就是 MTV 设计模式:
MTV是Model-Template-View(模型-模板-视图)的缩写,主要应用于Django框架中。其本质和MVC相同,Model依然表示数据和业务逻辑,View依然表示用户界面,但是Controller则变成了Template。Template主要负责渲染数据到HTML模板,而View则负责数据的处理和逻辑判断。
MTV 设计模式示意图如下:
我们按照 MVC 的设计模式对 MTV 进行分析,MTV 设计模式中,用 View 层取代了 Controller 层的位置,用Template 层取代了原来 View 层的位置。
MTV 设计模式的请求与响应过程描述如下:
通过以上两种设计模式的比较, 我们可以得出 MTV 是 MVC 的一种细化,将原来 MVC 中的 V层拿出来进行分离,视图的显示与如何显示交给 Template 层,而 View 层更专注于实现业务逻辑。其实在 Django 是有Controller 层的,只不过它由框架本身来实现,所以我们不用关心它。Django 更关注于M、T 和 V。
因为考虑到新的python版本更新和新的mysql数据库版本,由此使用python3.8和Django 4.1
在Django 3.2中,ASGI的支持已经得到了很大的改进,但是在Django4.1中,ASGI的支持得到了更多的增强和改进,包括更好的性能和更多的功能。
在Django 3.2中,Type annotations得到了一些支持,但是在Django 4.1中,Type
annotations的支持得到了进一步的扩展和增强。
Django 4.1对Admin后台管理进行了一些改进,包括更好的UI设计、更好的性能和更多的功能。
Django 4.1在官方文档中建议使用MySQL 5.7或MySQL8.0进行数据库的存储,但也可以使用其他MySQL的版本。与Python版本的选择类似,选择MySQL的版本主要考虑Django 4.1支持的版本以及个人项目的实际需求。
以下是一些常见的MySQL版本选择:
在cmd命令行执行如下命令进行在线安装,安装时可以指定版本号:
pip install django==4.1
推荐使用国内的清华镜像源:
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple django==4.1
检查是否安装成功:
通过 CMD 命令行中进入 Python 交互解释器,用以下方式检查 Django 是否安装成功,若能成功返回 Django 版本号,则说明安装成功:
import django django.get_version()
本节我们将学习如何创建 Django 项目以及 Django 项目的初始化,我们将创建一个名为 BookStore 的 Django 项目,用此项目来讲解 Django 框架的部分知识,通过这个项目我们将一起打开 Django 世界的大门。
我们创建一个名为Book的文件夹,用它来承载Bookstore项目。
在CMD命令行使用cd命令进入新建的Book文件夹,然后使用如下命令创建BookStore项目:
django-admin startproject Bookstore
startproject 是 django-admin 的子命令,它是专门用来创建 Django 项目的。
在pycharm里面创建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 协议并负责网络通讯部分的实现,只有在项目部署的时候才会用到它。
asgi.py文件
在Django 4.1版本中,创建asgi.py是为了支持ASGI(Asynchronous Server GatewayInterface)协议的Web服务器,以便更好地支持异步I/O编程模型和更好的性能。
ASGI协议替代了传统的WSGI(Web Server Gateway Interface)协议,在Django3.0版本中开始支持ASGI,Django 4.1版本中进一步完善了对ASGI的支持。
asgi.py文件中默认包含ASGI应用程序实例,该应用程序实例管理了一系列的middlewares和routes等信息,用于处理客户端的请求,并返回响应数据。在使用ASGI协议时,可以通过asgi.py文件来配置ASGI应用程序,以便更好地支持异步I/O模型和更高的性能。
在 CMD 命令行工具中,执行cd命令进入 Book/BookStore 目录下,我们知道在 BookStore 子目录下有一个 manage.py 文件,而这个文件的主要作用之一就是用来启动项目的,所以必须和 manage.py 文件处于同一个路径下才可以执行启动命令。
启动项目的命令如下所示:
python manage.py runserver
方法二:
在pycharm的Terminal中输入以下命令:
在浏览器地址栏输入 http://127.0.0.1:8000 进行访问,如下图所示:
当你在地址栏回车的一瞬间,若出现了如图所示的界面后,那么恭喜你,表示项目的骨架已经搭建完成了。
其实你会发现我们只是用了一个启动命令,就实现一个站点的访问功能,这就是 Django 框架的优势所在,Django 框架依靠创建项目时生成的配置文件,从而构建了自身功能的完整性。
我们使用如下命令启动了项目:
python manage.py runserver
Django的默认启动端口是8000,当然也可以选定其他端口来启用。
比如,你想在你的计算机上启动多个 Django 项目,那么就需要多个端口启动不同的项目,否则就会出现端口重用的问题,那么如何通过指定端口号启动项目呢?我们可以使用如下命令格式:
python manage.py runserver 7000
上面的命令表示的是以 7000 端口启动项目。
settings.py 配置文件,它是 Django 框架的重要配置文件,它定义的一些全局变量用来给 Django 框架传递参数,我们还可以根据自己的实际需求来修改这个文件从而实现某些特定的要求。下面我们对这个配置文件进行详细介绍,了解这个配置文件,是迈进 Django 世界的重要一步。
首先使用 Pycharm 打开 BookStore 项目,注意此时的根目录是一级子目录 BookStore,而不是 Book 目录,如图所示:
下面对 settings.py 配置文件涉及到的知识点进行依次讲解:
BASE_DIR
它用于绑定当前项目 BookStore 所在的绝对路径,项目中的所有的文件都需要依赖此路径,绑定路径的方法如下:
BASE_DIR = Path(__file__).resolve().parent.parent
__file__是python的语法,显示当前文件的位置。
SECRET_KEY
在Django中,SECRET_KEY通常定义在settings.py文件中,每个Django实例都应该有自己独特的SECRET_KEY。Django在创建新项目时会自动创建一个包含一些随机字符串的SECRET_KEY。在实际应用中,最佳实践是将SECRET_KEY存储在环境变量或机密存储中,而不是硬编码在应用代码中。
DEBUG
用于配置 Django 项目的启用模式,有两种取值方式:
ALLOWED_HOSTS
这个参数是指当前项目中用来安装的应用(APP)的列表,Django 把默认自带的应用放在这个列表里,比如 Admin 后台应用、Auth
用户管理系统等。
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', ]
MIDDLEWARE
它用于注册中间件,Django 默认加载了一些中间件。例如,用于处理会话的 SessionMiddleware 等,同样我们可以对这些中间件进行添加或者注释。
ROOT_URLCONF
ROOT_URLCONF = 'Bookstore.urls'
它指定了当前项目的根 URL,是 Django 路由系统的入口。
TEMPLATES
它用于指定模板的配置信息,列表中每一元素都是一个字典。
WSGI_APPLICATION
项目部署时,Django 的内置服务器将使用的 WSGI 应用程序对象的完整 Python 路径。
DATABASES
它用于指定数据库配置信息,这里默认配置的是 Django 自带的 sqllite3 数据库。Django 支持多种数据库,在这个字典变量中更改数据库配置。在后续章节我们将对 Mysql 数据库配置进行讲解。
AUTH_PASSWORD_VALIDATORS
这是一个支持插拔的密码验证器,且可以一次性配置多个,Django 通过这些内置组件来避免用户设置的密码等级不足的问题。
LANGUAGE_CODE和TIME_ZONE
分别代表语言配置项和当前服务端时区的配置项,我们常用的配置如下所示:
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适用项目,都要对这个默认配置文件进行相应的修改,那么我们应该如何修改呢,有哪几个重要的步骤呢?下面总结了配置文件的一些通用修改项,让我们一起来看看。
在项目中设置语言、时区是必不可少的。
打开 settings.py 文件,在文件的末尾部分找到相应的变量进行配置,如下所示:
# 设置为中文模式 LANGUAGE_CODE = 'zh-Hans' TIME_ZONE = 'Asia/Shanghai'
然后访问 127.0.0:8000 来验证,发现已经变成了中文模式,如图所示:
当 USE_TZ 设置为 False 时,表示对时区不敏感,并且让数据库时间符合本地时区。
在 Django 项目中配置数据库是必不可少的,我们使用 MySQL 作为项目的数据库。
如果我们在Django中要连接mysql数据库,需要安装一个库(mysqlclient)
下面是 Django 默认配置的 sqlite3 数据库:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 引擎 'NAME': BASE_DIR / 'db.sqlite3', 名称 } }
在配置 MySQL 数据库之前,先进入 MySQL 命令行界面为项目建库,使用如下命令:
CREATE DATABASE bookstoredb;
然后在 settings.py 文件中配置 MySQL 数据库,如下所示:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', # 使用的数据库的引擎 'NAME': 'bookstoredb', # 数据库 'USER': 'root', # 账号 'PASSWORD': '000000', # 密码 'HOST': '127.0.0.1', # 主机ip 'PORT': '3306', # 端口 } }
注意:配置是根据自己的数据库的密码来,不要copy上述代码。
下面我们对上述DATABASES中的字典元素进行介绍:
Django 允许我们在项目运行过程中直接修改配置文件,但如果配置文件出错,那么错误信息将会输出到该项目对应的命令行。
如下所示:
说明没有安装mysqlclient,此时就需要安装一下。
以上就是对 settings.py 的文件的基本修改,当然 settings.py 还可以进行很多的配置,比如模板配置或者静态文件路径的配置,但是这些配置需要根据项目实际要求而定,在后续章节会对其进行介绍。
【本期赠书】:Python从入门到精通(微课精编版)
优惠图书请看下方:
618,清华社 IT BOOK 多得图书活动开始啦!活动时间为2023年6月7日至6月18日,清华社为您精选多款高分好书,涵盖了C++、Java、Python、前端、后端、数据库、算法与机器学习等多个IT开发领域,适合不同层次的读者。全场5折,扫码领券更有优惠哦!快来京东点击链接IT BOOK多得https://pro.m.jd.com/mall/active/3Rho97HkMaGFycLzAWfFdvZdyvRn/index.html
🎁🎁抽奖方式:评论区随机抽取3位小伙伴免费送出!!
参与方式:关注博主、点赞、收藏、评论区评论“人生苦短,我爱Python!”(切记要点赞+收藏,否则抽奖无效,每个人最多评论三次!)
活动截止时间:2023-06-18 20:00:00
上一篇:linux查看nginx安装路径