Django Framework 手册 | 03 - Django 处理 GET 与 POST 请求

·  阅读 10
Django Framework 手册 | 03 - Django 处理 GET 与 POST 请求

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第3天,点击查看活动详情

一、HTTP协议的请求和响应

  • 请求是指浏览器端通过HTTP协议发送给服务器端的数据
  • 响应是指服务器端接收到请求后做相应的处理后再回复给浏览器端的数据

图片.png

HTTP 请求

HTTP 请求的内容如下:

GET /user_api/v1/user/profile_id?aid=208&uuid=7162& HTTP/2 # 起始行

Host: api.juejin.cn # 请求头
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:107.0) Gecko/20100101 Firefox/107.0
Accept: */*
Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2
Accept-Encoding: gzip, deflate, br
Referer: https://juejin.cn/
Content-Type: application/json
Origin: https://juejin.cn
Connection: keep-alive
Cookie: _tea_utm_cache_2608={%25; sessionid=d11f6cd29c10cdcbb17c8525; sessionid_ss=d11f61MjU; 
Sec-Fetch-Dest: empty
Sec-Fetch-Mode: cors
Sec-Fetch-Site: same-site
TE: trailers
复制代码

根据HTTP标准,HTTP请求可以使用多种请求方法。

  • HTTP 1.0 定义了三种请求方法: GET, POST 和 HEAD方法(最常用)

  • HTTP 1.1 新增了五种请求方法:OPTIONS, PUT, DELETE, TRACE 和 CONNECT 方法。

    HTTP 1.1 中的方法含义如下:

    方法描述
    GET请求指定的页面信息,并返回实体主体。
    HEAD类似于get请求,只不过返回的响应中没有具体的内容,用于获取报头
    POST向指定资源提交数据进行处理请求(例如提交表单或者上传文件)。数据被包含在请求体中。POST请求可能会导致新的资源的建立和/或已有资源的修改。
    PUT从客户端向服务器传送的数据取代指定的文档的内容。
    DELETE请求服务器删除指定的页面。
    CONNECTHTTP/1.1协议中预留给能够将连接改为管道方式的代理服务器。
    OPTIONS允许客户端查看服务器的性能。
    TRACE回显服务器收到的请求,主要用于测试或诊断。

Django 视图函数的第一个参数就是一个 HttpRequest 对象,服务器接收到 http 协议的请求后,会根据请求数据报文创建 HttpRequest 对象。

HttpRequest 属性包含了以下属性:

  • path_info: URL字符串
  • method:字符串,表示HTTP请求方法,常用值:'GET'、'POST'
  • GET:QueryDict查询字典的对象,包含查询字符串的所有数据
  • POST:QueryDict查询字典的对象,包含post表单提交方式的所有数据
  • FILES:类似于字典的对象,包含所有的上传文件信息
  • COOKIES:Python字典,包含所有的cookie,键和值都为字符串
  • session:似于字典的对象,表示当前的会话
  • body: 字符串,请求体的内容(POST或PUT)
  • scheme : 请求协议('http'/'https')
  • request.get_full_path() : 请求的完整路径
  • request.get_host() : 请求的主机
  • request.META : 请求中的元数据(消息头)
  • request.META['REMOTE_ADDR'] : 客户端IP地址

HTTP 响应

HTTP/2 200 OK # 起始行

server: Tengine # 响应头
content-type: application/json; charset=utf-8
content-length: 73
date: Sat, 26 Nov 2022 17:18:30 GMT
access-control-allow-credentials: true
access-control-allow-origin: https://juejin.cn
vary: Origin
x-tt-logid: 2022112701183001020816110519DEE723
server-timing: inner; dur=34
x-tt-trace-host: 1b9fc4b6
x-tt-trace-tag: id=03;cdn-cache=miss;type=dyn
x-tt-timestamp: 1669483110.986
server-timing: cdn-cache;desc=MISS,edge;dur=0,origin;dur=69
via: cache18.cn2580[69,0]
timing-allow-origin: *
eagleid: dde5ca2616694831109325056e
X-Firefox-Spdy: h2

{"err_no":0,"err_msg":"success","data":{"profile_id":"3329771602453447"}} # 响应数据
复制代码

当访问一个网页时,浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前,此网页所在的服务器会返回一个包含 HTTP 状态码的信息头用以响应浏览器的请求。

常见的 HTTP 状态码包括:

  • 200 - 请求成功
  • 301 - 永久重定向-资源(网页等)被永久转移到其它URL
  • 302 - 临时重定向
  • 404 - 请求的资源(网页等)不存在
  • 500 - 内部服务器错误

HTTP状态码由三个十进制数字组成,第一个十进制数字定义了状态码的类型,后两个数字没有分类的作用。HTTP状态码共分为5种类型:

分类分类描述
1xx信息,服务器收到请求,需要请求者继续执行操作
2xx成功,操作被成功接收并处理
3xx重定向,需要进一步的操作以完成请求
4xx客户端错误,请求包含语法错误或无法完成请求
5xx服务器错误,服务器在处理请求的过程中发生了错误

Django 中的响应对象 HttpResponse

HttpResponse 向客户端浏览器返回响应,同时携带响应体内容

# HttpResponse 对象的构造函数
HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)
复制代码

参数:

  • content:表示返回的内容。
  • status_code:返回的HTTP响应状态码(默认为200)。
  • content_type:指定返回数据的的MIME类型(默认为"text/html")。浏览器会根据这个属性,来显示数据。如果是text/html,那么就会解析这个字符串,如果text/plain,那么就会显示一个纯文本。

常用的 Content-Type 如下:

  • 'text/html'(默认的,html文件)
  • 'text/plain'(纯文本)
  • 'text/css'(css文件)
  • 'text/javascript'(js文件)
  • 'multipart/form-data'(文件提交)
  • 'application/json'(json传输)
  • 'application/xml'(xml文件)

plus:关键字MIME(Multipurpose Internet Mail Extensions)是指多用途互联网邮件扩展类型。

HttpResponse 子类包含了:

类型作用状态码
HttpResponseRedirect重定向302
HttpResponseNotModified未修改304
HttpResponseBadRequest错误请求400
HttpResponseNotFound没有对应的资源404
HttpResponseForbidden请求被禁止403
HttpResponseServerError服务器错误500

二、Django 处理 GET 和 POST 请求

无论客户端发送的是 GET请求还是 POST 请求,都统一都由视图函数接收请求,通过 request.method 获取到具体的请求方式, 根据请求方式区分具体的请求动作。

if request.method == 'GET':
    # 处理GET请求时的业务逻辑
elif request.method == 'POST':
    # 处理POST请求的业务逻辑
else:
    # 其他请求业务逻辑
复制代码

GET处理

GET 请求动作一般用于向服务器获取数据。

以下操作能够向服务端发送 GET 请求:

  • 浏览器地址栏中输入URL,回车后
  • <a href="地址?参数=值&参数=值">
  • form表单中的method为get
    <form method='get' action="/user/login">
        姓名:<input type="text" name="uname">
    </form>
    复制代码

GET 请求方式中,如果有数据需要传递给服务器,通常会用查询字符串 (Query String) 传递

  • URL 格式: xxx?参数名1=值1&参数名2=值2...
    • 如: http://127.0.0.1:8000/page1?a=100&b=200
  • 服务器端接收参数,获取客户端请求GET请求提交的数据
    request.GET['参数名']  # QueryDict
    request.GET.get('参数名','默认值')
    request.GET.getlist('参数名')
    # mypage?a=100&b=200&c=300&b=400
    # request.GET=QueryDict({'a':['100'], 'b':['200','400'], 'c':['300']})
    # a = request.GET['a']
    # b = request.GET['b']  # Error
    复制代码

POST处理

POST 请求一般用于向服务器提交大量数据。

客户端可以通过表单等发送 POST 请求将数据传递给服务器端:

<form method='post' action="/login">
    姓名:<input type="text" name="username">
    <input type='submit' value='登陆'>
</form>
复制代码

在 form 表单控件提交数据时,会自动搜索本表单控件内部的子标签的 name 属性及相应的值,再将这些名字和值以键-值对的形式提交给 action 指定的服务器相关位置

在form内能自动搜集到的name属性的标签的控件有

<input name='xxx'>
<select name='yyy'></select>
<textarea name='zzz'></textarea>
复制代码

服务器端接收参数可以通过 request.method 来判断是否为 POST 请求,如:

if request.method == 'POST':
    # 处理POST请求的数据并响应
else:
    # 处理非POST 请求的响应
复制代码

使用post方式接收客户端数据

request.POST['参数名']  # request.POST 绑定QueryDict
request.POST.get('参数名','')
request.POST.getlist('参数名')
复制代码

要注意取消 csrf 验证,否则 Django 将会拒绝客户端发来的 POST 请求:

# settings.py

MIDDLEWARE = [
    ...
    # 'django.middleware.csrf.CsrfViewMiddleware',
    ...
]
复制代码
收藏成功!
已添加到「」, 点击更改