django中的request用来获取前端传过来的数据,那么前端数据的发送方式有多种,每一种传输方式在后端对应的接收方式也不同,所以我们首先来看前端的几种数据发送方式:
对于这种数据,它在前端的url中,比如:www.baidu.com/id/
我们就可以获取这个url中的id
方法:
在定义好的视图函数或者视图类的函数中的参数加上这个id即可
比如:
def weather(request, id):
print('id=%s' % id)
return HttpResponse('OK')
什么是查询字符串?看下边的例子就好
www.baidu.com/data/?a=10&b=20&a=30 (这个路径中有两个a,因为前端有时会有一键多值的情况)
对于这种请求怎么获取a,b这两个数据呢
我们可以通过request.GET属性来获取(HttpRequest对象的属性GET、POST都是QueryDict类型的对象,通过QueryDict对象request.GET/request.POST来获取一键多值的数据)
重要:查询字符串不区分请求方式,即假使客户端进行POST方式的请求,依然可以通过request.GET获取请求中的查询字符串数据。
方法:
def qs(request):
a = request.GET.get('a')
b = request.GET.get('b')
alist = request.GET.getlist('a')
print(a) # 30
print(b) # 20
print(alist) # ['10', '30']
return HttpResponse('OK')
表单数据的获取通过request.POST返回的Query Dict对象来获取
注意:request.POST只能用来获取POST方式的请求体表单数据。
方法:request.POST.get()和request.POST.getlist()
如:
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')
非表单类型的请求体数据,Django无法自动解析,可以通过request.body属性获取最原始的请求体数据,自己按照请求体格式(JSON、XML等)进行解析。
request.body返回bytes类型。
例如要获取请求体中的如下JSON数据{"name": "fenghua", "age": 24}
方法:因为获取到的是原始二进制数据,要进行解码(字符串化,得到json数据),json_dict化(将json数据转换成字典)
例如:
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['name'])
print(req_data['age'])
return HttpResponse('OK')
可以通过request.META属性获取请求头headers中的数据,request.META为字典类型。
常见的请求头如:
CONTENT_LENGTH – The length of the request body (as a string).
CONTENT_TYPE – The MIME type of the request body.
HTTP_ACCEPT – Acceptable content types for the response.
HTTP_ACCEPT_ENCODING – Acceptable encodings for the response.
HTTP_ACCEPT_LANGUAGE – Acceptable languages for the response.
HTTP_HOST – The HTTP Host header sent by the client.
HTTP_REFERER – The referring page, if any.
HTTP_USER_AGENT – The client’s user-agent string.
QUERY_STRING – The query string, as a single (unparsed) string.
REMOTE_ADDR – The IP address of the client.
REMOTE_HOST – The hostname of the client.
REMOTE_USER – The user authenticated by the Web server, if any.
REQUEST_METHOD – A string such as "GET" or "POST".
SERVER_NAME – The hostname of the server.
SERVER_PORT – The port of the server (as a string).
方法:
def get_headers(request):
print(request.META['REQUEST_METHOD'])
return HttpResponse('haha')
method:一个字符串,表示请求使用的HTTP方法,常用值包括:'GET'、'POST'。
user:请求的用户对象。
path:一个字符串,表示请求的页面的完整路径,不包含域名和参数部分。
encoding:一个字符串,表示提交的数据的编码方式。
如果为None则表示使用浏览器的默认设置,一般为utf-8。
这个属性是可写的,可以通过修改它来修改访问表单数据使用的编码,接下来对属性的任何访问将使用新的encoding值。
FILES:一个类似于字典的对象,包含所有的上传文件。
响应的常见类型:
HttpResponse,
HttpResponse子类(如HttpResponseNotFound 404),
JsonResponse,
redirect重定向,
render
response = HttpResponse()
response['name'] = ‘fenghua'
响应体的添加:
方式1:直接返回
return HttpResponse(content=响应体, content_type=响应体数据类型, status=状态码)
方式2:构造响应对象
response = HttpResponse(响应体)
response.status_code = 状态码
return response
return HttpResponseNotFound(响应体内容) # 返回的状态码自动设置成404,并显示前端显示的数据
返回json格式数据,并将响应头的Content-Type设置成application/json
# 响应json数据到前端
def response_json(request):
data_json = {"name": "fenghua", "age": 24}
# 默认把json_dict转成了json字符串
# 再默认把json字符串转成二进制的json字符串
# 默认将数据类型指定为 application/json
return JsonResponse(data_json)
反向解析reverse:根据路由名称或者命名空间解析出url路径
反向解析:要是命名空间是以分离的方式:url(r'^users/', include('users.urls', namespace='users111'))
url(r'^index/$', views.index, name='index111')
则reverse方式为:reverse('users111:index111')
或者:reverse('users:index')
要是以一次性在主url写好的方式:url(r'^users/feng', views.feng, name='feng')
则reverse方式为:reverse('feng')
redirect:根据反向解析出来的路径进行重定向
具体使用如下:
# 需求:访问'response_redirect/'重定向到 'users.index'
def response_redirect(request):
# url(r'^users/', include('users.urls', namespace='users111'))
# url(r'^index/$', views.index, name='index111')
return redirect(reverse('users:index')) # redirect(reverse('users111:index111')) 也可以实现
用法:
render(request对象, 模板文件路径, 模板数据字典)
from django.shortcuts import render
def index(request):
context={'city': '北京'}
return render(request,'index.html',context)