首页 > python web
时间:2021-03-03 python web 查看: 1050
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')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持python博客。