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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。