最短时间攻透最完善的Python框架——Django⑦

Django请求详讲

在本篇博文开始前请大家回想一下,利用HTTP协议向服务器传参有几种途径?

  • 提取URL的特定部分,如/ weather /shanghai/ 2020,可以在服务器端的路由中用正则表达式(re)截取;
  • 查询字符串(query string),如:key1 = value1&key2 = value2;
  • 请求体(body)中发送的数据,多种表单数据:json,xml;
  • 在http报文中的头部(header)

1.路径参数

在定义路由URL时,可以使用正则表达式(re)提取参数的方法从URL中获取请求参数,Django替换提取的参数直接传递到视图的参数中

  • 未命名参数按定义顺序传递

    url(r'^weather/([a-z]+)/(\d{4})/$', views.weather),
    
    def weather(request, city, year):
        print('city=%s' % city)
        print('year=%s' % year)
        return HttpResponse('OK')
    
  • 命名参数按名字传递

    url(r'^weather/(?P<city>[a-z]+)/(?P<year>\d{4})/$', views.weather),
    
    def weather(request, year, city):
        print('city=%s' % city)
        print('year=%s' % year)
        return HttpResponse('OK')
    

2.QueryDict对象

定义在django.http.QueryDict

HttpRequest对象的属性GET,POST都是QueryDict类型的对象

与Python字典不同,QueryDict类型的对象用来处理同一个键带有多个值的情况

  • 方法get():

  • 根据键获取值

    如果一个键同时拥有多个值将获取最后一个值

    如果键不存在则返回None值,可以设置替换值进行后续处理

    dict.get('键',默认值)
    可简写为
    dict['键']
    
  • 方法getlist():

  • 根据键获取值,值以列表返回,可以获取指定键的所有值

    如果键不存在则返回空列表[],可以设置默认值进行后续处理

    dict.getlist('键',默认值)
    

HaoXuan

3.查询字符串

获取请求路径中的查询字符串参数(形如:k1 = v1&k2 = v2),可以通过request.GET属性获取,返回QueryDict对象。

访问路径:/user/qs/?a=1&b=2&a=3

def num(request):
    a = request.GET.get('a')
    b = request.GET.get('b')
    alist = request.GET.getlist('a')
    print(a)  # 3
    print(b)  # 2
    print(alist)  # ['1', '3']
    return HttpResponse('OK')

注意:查询字符串不区分请求方式,假使客户端进行POST方式的请求,依然可以通过request.GET获取请求中的查询字符串数据。

4.请求体调度

请求体数据格式不固定,可以是表单类型字符串,可以是JSON字符串,可以是XML字符串,应区别对待。

可以发送请求体数据的请求方式有POSTPUTPATCHDELETE

Django开启了CSRF防护

通过上述请求方式进行CSRF防护验证,在测试时可以关闭CSRF防护机制,方法为在settings.py文件中注释掉CSRF防护件(后续会说到其他方法)如:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wdQoKRlK-1590502479466)(最短时间攻透最完善的Python框架——Django⑦.assets/image-20200526220354632.png)]

4.1表单类型表格数据

前端发送的表单类型的请求体数据,可以通过request.POST属性获取,返回QueryDict对象。

def get_body(request):
    a = request.POST.get('a')
    b = request.POST.get('b')
    alist = request.POST.getlist('a')
    print(a)
    print(b)
    print(alist)
    return HttpResponse('OK')

注意:request.POST只能获取获取POST方式的请求体表单数据。**

4.2非表单类型非表格数据

非表单类型的请求体数据,Django无法自动解析,可以通过request.body属性获取最原始的请求体数据,自己按照请求体格式(JSON,XML等)进行解析**。request.body返回字节类型。**

例如要获取请求体中的如下JSON数据

{"a": 1, "b": 2}

可以进行如下方法操作:

import json

def get_body_json(request):
    json_str = request.body
    json_str = json_str.decode()  # python3.6 无需执行此步
    req_data = json.loads(json_str)
    print(req_data['a'])
    print(req_data['b'])
    return HttpResponse('OK')

5.请求头汇总

可以通过request.META属性获取请求头headers中的数据,request.META为字典类型

常见的请求头如下:

  • CONTENT_LENGTH –请求主体的长度(以字符串形式)。
  • CONTENT_TYPE –请求正文的MIME类型。
  • HTTP_ACCEPT –响应可接受的内容类型。
  • HTTP_ACCEPT_ENCODING –响应的可接受编码。
  • HTTP_ACCEPT_LANGUAGE –可接受的响应语言。
  • HTTP_HOST –客户端发送的HTTP Host标头。
  • HTTP_REFERER –推荐页面(如果有)。
  • HTTP_USER_AGENT –客户端的用户代理字符串。
  • QUERY_STRING –查询字符串,作为单个(未分析)字符串。
  • REMOTE_ADDR –客户端的IP地址。
  • REMOTE_HOST –客户端的主机名。
  • REMOTE_USER –由Web服务器验证的用户(如果存在)。
  • REQUEST_METHOD–诸如"GET"或字符串"POST"
  • SERVER_NAME –服务器的主机名。
  • SERVER_PORT –服务器的端口(以字符串形式)。

具体使用方法如:

def get_headers(request):
    print(request.META['CONTENT_TYPE'])
    return HttpResponse('OK')

6.HttpRequest对象属性

  • method:一个字符串,表示请求使用的HTTP方法,常用值包括:‘GET’,‘POST’

  • user:请求的用户对象。

  • path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。

  • encoding:一个字符串,表示提交的数据的编码方式。

    • 如果为None则表示使用浏览器的替代设置,一般为utf-8。
    • 这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,然后对属性的任何访问将使用新的编码值。
  • FILES:一个透析字典的对象,包含所有的上传文件。
    今天的知识点主在了解,希望大家在阅读后有所收获,欧耶,谢谢观赏
    -在这里插入图片描述
    @Author:HaoXuan

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章