Django 请求Request的具体使用方法
作者:冒牌技术小哥
1 URL路径参数
在定义路由URL时,使用正则表达式提取参数的方法从URL中获取请求参数,Django会将提取的参数直接传递到视图的传入参数中。
未命名参数按顺序传递, 如
url(r'^index/([a-z]+)/(\d{4})/$', views.index), def index(request, parameter1, parameter2): print(parameter1) print(parameter2) return HttpResponse('OK')
有命名参数按名传递,如
url(r'^index/(?P<parameter1>[a-z]+)/(?P<parameter2>\d{4})/$', views.index), def index(request, parameter1, parameter2): print(parameter1) print(parameter2) return HttpResponse('OK')
2、 查询字符串Query String
获取请求路径中的查询字符串参数,可以通过request.GET属性获取,返回QueryDict对象。
# /q/?a=2&b=3&a=4 def q(request): a = request.GET.get('a') b = request.GET.get('b') alist = request.GET.getlist('a') print(a) # 4 print(b) # 3 print(alist) # ['2', '4'] return HttpResponse('OK')
2、 QueryDict对象
HttpRequest对象的属性GET、POST都是QueryDict类型的对象
方法get():根据键获取值
如果一个键同时拥有多个值将获取最后一个值
如果键不存在则返回None值,可以设置默认值进行后续处理
dict.get('键',默认值) 可简写为 dict['键']
方法getlist():根据键获取值,值以列表返回,可以获取指定键的所有值
如果键不存在则返回空列表[],可以设置默认值进行后续处理
dict.getlist('键',默认值)
3、 请求体
请求体数据格式不固定,可以是表单类型字符串,可以是JSON字符串,可以是XML字符串,应区别对待。
可以有POST、PUT、PATCH、DELETE。
Django默认开启了CSRF防护,会对上述请求方式进行CSRF防护验证,在测试时可以关闭CSRF防护机制,方法为在settings.py文件中注释掉CSRF中间件,如:
4、 表单类型 Form Data
前端发送的表单类型的请求体数据,可以通过request.POST属性获取,返回QueryDict对象
def 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')
5、非表单类型 Non-Form Data
非表单类型的请求体数据,Django无法自动解析,可以通过request.body属性获取最原始的请求体数据。
import json def body_json(request): json_str = request.body json_str = json_str.decode() # python3.6 无需这步 data = json.loads(json_str) print(data['a']) print(data['b']) return HttpResponse('OK')
6、请求头
可以通过request.META属性获取请求头headers中的数据
def headers(request): print(request.META['SERVER_PORT']) return HttpResponse('OK')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。