Django 请求Request的具体使用方法
1URL路径参数
在定义路由URL时,使用正则表达式提取参数的方法从URL中获取请求参数,Django会将提取的参数直接传递到视图的传入参数中。
未命名参数按顺序传递,如
url(r'^index/([a-z]+)/(\d{4})/$',views.index), defindex(request,parameter1,parameter2): print(parameter1) print(parameter2) returnHttpResponse('OK')
有命名参数按名传递,如
url(r'^index/(?P[a-z]+)/(?P \d{4})/$',views.index), defindex(request,parameter1,parameter2): print(parameter1) print(parameter2) returnHttpResponse('OK')
2、查询字符串QueryString
获取请求路径中的查询字符串参数,可以通过request.GET属性获取,返回QueryDict对象。
#/q/?a=2&b=3&a=4 defq(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'] returnHttpResponse('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、表单类型FormData
前端发送的表单类型的请求体数据,可以通过request.POST属性获取,返回QueryDict对象
defbody(request): a=request.POST.get('a') b=request.POST.get('b') alist=request.POST.getlist('a') print(a) print(b) print(alist) returnHttpResponse('OK')
5、非表单类型Non-FormData
非表单类型的请求体数据,Django无法自动解析,可以通过request.body属性获取最原始的请求体数据。
importjson defbody_json(request): json_str=request.body json_str=json_str.decode()#python3.6无需这步 data=json.loads(json_str) print(data['a']) print(data['b']) returnHttpResponse('OK')
6、请求头
可以通过request.META属性获取请求头headers中的数据
defheaders(request): print(request.META['SERVER_PORT']) returnHttpResponse('OK')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。