Django
python网络编程回顾
之前我们介绍过web应用程序和http协议,简单了解过web开发的概念。Web应用程序的本质
- 接收并解析HTTP请求,获取具体的请求信息
- 处理本次HTTP请求,即完成本次请求的业务逻辑处理
- 构造并返回处理结果——HTTP响应
- import socket
- server = socket.socket()
- server.bind(('127.0.0.1',8000))
- server.listen(5)
- while True:
- conn,addr = server.accept()
- data = conn.recv(1024)
- print("data:\n", data)
复制代码 即一般我们接受到的数据就是一串网络报文
那么我们可以根据返回的一些内容进行路径的解析- request_path = data.decode('utf-8').split('\r\n')[0].split(' ')[1]
- if request_path == '/':
- with open("index.html", "rb") as f:
- data = f.read()
- conn.send(b'HTTP/1.1 200 OK\r\n\r\n' + data)
- elif request_path == '/timer':
- with open("login.html", "rb") as f:
- data = f.read()
- conn.send(b'HTTP/1.1 200 OK\r\n\r\n' + data)
- else:
- with open("notFound.html", "rb") as f:
- data = f.read()
- conn.send(b'HTTP/1.1 404 Not Found\r\n\r\n' + data)
复制代码 每次的分发路由会有很多个,依次罗列会非常麻烦,所以进入一个web框架的概念
Web应用框架有助于减轻网页开发时共通性活动的工作负荷,例如许多框架提供数据库访问接口、标准样板以及会话管理等,可提升代码的可再用性。
说简单点就是web框架用于搭建Web应用程序,免去不同Web应用相同代码部分的重复。
Django介绍

Django文档
Django 采用了 MVT 的软件设计模式,即模型(Model),视图(View)和模板(Template)。
这个MVT模式并非django首创,在其他的语言里面也有类似的设计模式MVC,甚至可以说django里面的MVT事实上是借鉴了MVC模式衍生出来的。
M,Model,模型,是用于完成操作数据库的。
V,View,视图,里面的代码就是用于展示给客户端的页面效果。
C,Controller,控制器,是一个类或者函数,里面的代码就是用于项目功能逻辑的,一般用于调用模型来获取数据,获取到的数据通过调用视图文件返回给客户端。
而MVT指的是:
- M全拼为Model,与MVC中的M功能相同,负责和数据库交互,进行数据处理。
- V全拼为View,与MVC中的C功能相同,接收请求,进行业务处理,返回应答。
- T全拼为Template,与MVC中的V功能相同,负责封装构造要返回的html。
路由控制器将请求转发给对应的视图函数,完成业务逻辑,视图函数将从model中获取的数据嵌入到template的中模板文件(html)渲染成一个页面字符串,返回给客户端的流程。
所以学习Django重点是四个部分:url路由器+MVT
Django的安装
官网: http://www.djangoproject.com
文档:https://docs.djangoproject.com/zh-hans/3.2/
在本地安装- pip install django
- pip install django==3.2
复制代码- pip源:
- https://pypi.douban.com/simple/ 豆瓣源
- https://pypi.tuna.tsinghua.edu.cn/simple 清华源
-
- 使用格式:
- pip install django -i https://pypi.douban.com/simple/
复制代码- # 查看django版本号
- django-admin --version
复制代码 当然在以后开发或者学习中,我们肯定都会遇到在一台开发机子中,运行多个项目的情况,有时候还会出现每个项目的python解析器或者依赖包的版本有差异.

Django的启动和运行
创建好了虚拟环境可以直接运用命令建立一个django文件,命令有下面这些- ivanlee@ivanleedeMacBook-Pro ~ % django-admin
- Type 'django-admin help <subcommand>' for help on a specific subcommand.
- Available subcommands:
- [django]
- check
- compilemessages
- createcachetable
- dbshell
- diffsettings
- dumpdata
- flush
- inspectdb
- loaddata
- makemessages
- makemigrations
- migrate
- runserver
- sendtestemail
- shell
- showmigrations
- sqlflush
- sqlmigrate
- sqlsequencereset
- squashmigrations
- startapp
- startproject
- test
- testserver
复制代码 使用startproject可以新建一个项目

建立好项目以后,他会自带的形成很多的目录文件框架- ivanlee@ivanleedeMacBook-Pro Desktop % tree Regina
- Regina
- ├── Regina
- │ ├── __init__.py
- │ ├── asgi.py
- │ ├── settings.py
- │ ├── urls.py
- │ └── wsgi.py
- └── manage.py
- 1 directory, 6 files
复制代码 通过命令行python3 manage.py runserver ip_port就可以直接启动,在网页上访问8090端口会显示一个静态模板网页


在项目中创建应用
创建子应用
pytho3 manage.py startapp appName- ivanlee@ivanleedeMacBook-Pro Regina % tree
- .
- ├── Regina
- │ ├── __init__.py
- │ ├── asgi.py django3.0以后新增的,用于让django运行在异步编程模式的一个web应用对象
- │ ├── settings.py 默认开发配置文件
- │ ├── urls.py 路由列表目录,用于绑定视图和url的映射关系
- │ └── wsgi.py wsgi就是项目运行在wsgi服务器时的入口文件,runserver默认启动的wsgi.py文件作为web服务器接口
- ├── Reginaapp 子应用
- │ ├── __init__.py
- │ ├── admin.py 该应用的后台管理系统配置
- │ ├── apps.py 该应用的一些配置,自动生成
- │ ├── models.py 该应用的模型类模块
- │ ├── tests.py 该应用的单元测试模块
- │ └── views.py 该应用的视图模块
- ├── db.sqlite3
- └── manage.py 终端脚本命令,提供了一系列用于生成文件或者目录的命令,也叫脚手架
- 4 directories, 18 files
复制代码 当然如果每次运行项目都要在终端下输入命令的话,很麻烦,这时候我们可以借助pycharm直接自动运行这段命令.当然,这个需要我们在pycharm配置一下的.

找到这个默认参数的位置,如果里面是空的,那么在运行manage.py的时候会自动报停,因为后面没有任何的命令参数



快速使用Django
在django中要提供数据展示给用户,我们需要完成3个步骤.
需求:利用Django实现一个查看当前时间的web页面。
基于MTV模型,设计步骤如下:
- step1:在urls.py中设计url与视图的映射关系。
- step2:创建子应用,在views.py中构建视图函数。
- step3:将变量嵌入到模板中返回客户端。
1. 创建子应用

2. 绑定路由
在djangoRegina.urls.py的文件里会自带一个默认的路由- from django.contrib import admin
- from django.urls import path
- urlpatterns = [
- path('admin/', admin.site.urls),
- ]
复制代码 如果这个文件不被修改的话,访问8090端口的时候默认就会显示一个静态页面,但如果手动添加了其他代码和路由进来的话,那么默认路由也会失效


那在自己编写路由的时候,可以分为以下两种情况
直接在urls文件里添加函数
- from django.contrib import admin
- from django.urls import path
- from django.shortcuts import HttpResponse 所有的网络报文必须都是同一种格式,所以导入这个模块方便了我们信息交换
- def get_ZJR(request): 这个函数叫做视图函数
- return HttpResponse("<img src='https://www.cnblogs.com/xxxx.jpeg'>") 返回一个已经封装好的报文
- urlpatterns = [
- path('admin/', admin.site.urls),
- path('ZJR/', get_ZJR),
- ]
复制代码
将试图函数集成在一个视图文件里
3. 构建视图函数
因为如果过多的视图函数都堆积在路由区域,代码会非常的复杂,所以可以归类到一个文件当中:ReginaApp.views.py- from django.shortcuts import render, HttpResponse
- # Create your views here.
- def get_ZJR(request):
- return HttpResponse("<img src='https://images.cnblogs.com/cnblogs_com/blogs/751189/galleries/2161669/o_220713040648_WechatIMG275.jpeg'>")
- def get_name(request):
- return HttpResponse("hello Ms JiaRui")
复制代码 再在djangoRegina.urls.py里进行导入- from django.contrib import admin
- from django.urls import path
- from django.shortcuts import HttpResponse
- from ReginaApp import views
- urlpatterns = [
- path('admin/', admin.site.urls),
- path('ZJR/', views.get_ZJR),
- path('name/', views.get_name), 这里的路由视图函数一定不加括号
- ]
复制代码
4. 构建模板
本身在与项目同名的子文件下的setting.py里,会有一个配置模板文件的目录

首先检查这个地方是否填充了目录,一般来说是自己带着的,之后在manage.py的同根目录下建立一个templates文件夹,里面虽然存放的都是html文件,但在django里叫做模板文件- def get_ZJR(request):
- return render(request,"regina.html")
复制代码 这样再导入的时候,就会去找templates/regina.html

5. 渲染文件
- def get_ZJR(request):
- now = datetime.datetime.now().strftime("%Y-%m-%d %X")
- return render(request,"regina.html",{"now":now})
复制代码 将要动态渲染的内容以字典的形式附加在函数末尾,在模板文件里被渲染的部分用{{}}引用- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
-
- </head>
- <body>
- <h3>IvanleeZJR {{now}}</h3>
- <img src="https://images.cnblogs.com/cnblogs_com/blogs/751189/galleries/2161669/o_220713040648_WechatIMG275.jpeg" alt="">
- </body>
- </html>
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |