Django 使用Request 对象和Response 对象在系统间传递状态。html
HttpRequest 对象:python
Request.body:一个字节字符串,表示原始HTTP 请求的正文。它对于处理非HTML 形式的数据很是有用:二进制图像、XML等。 若是要处理常规的表单数据,应该使用HttpRequest.POST。ajax
Request.path:一个字符串,表示请求的页面的完整路径,不包含域名:"/music/bands/the_beatles/"django
Request.path_info:在某些Web 服务器配置下,主机名后的URL 部分被分红脚本前缀部分和路径信息部分。path_info 属性将始终包含路径信息部分,不论使用的Web 服务器是什么。使用它代替path 可让代码在测试和开发环境中更容易地切换。json
Request.method:一个字符串,表示请求使用的HTTP 方法。必须使用大写(GET/POST)服务器
Request.GET:一个相似于字典的对象,包含HTTP GET 的全部参数cookie
Request.POST:一个包含全部给定的HTTP POST参数的类字典对象,提供了包含表单数据的请求。POST 不包含上传的文件信息。参见FILES。
app
Request.COOKIES:个标准的Python 字典,包含全部的cookie。键和值都为字符串。
Request.FILES:一个相似于字典的对象,包含全部的上传文件。FILES 中的每一个键为<input type="file"name="" /> 中的name。ide
FILES 只有在请求的方法为POST 且提交的<form> 带有enctype="multipart/form-data" 的状况下才会包含数据。不然,FILES 将为一个空的相似于字典的对象。函数
一个标准的Python 字典,包含全部的HTTP 头部。具体的头部信息取决于客户端和服务器,下面是一些示例: CONTENT_LENGTH —— 请求的正文的长度(是一个字符串)。 CONTENT_TYPE —— 请求的正文的MIME 类型。 HTTP_ACCEPT —— 响应可接收的Content-Type。 HTTP_ACCEPT_ENCODING —— 响应可接收的编码。 HTTP_ACCEPT_LANGUAGE —— 响应可接收的语言。 HTTP_HOST —— 客服端发送的HTTP Host 头部。 HTTP_REFERER —— Referring 页面。 HTTP_USER_AGENT —— 客户端的user-agent 字符串。 QUERY_STRING —— 单个字符串形式的查询字符串(未解析过的形式)。 REMOTE_ADDR —— 客户端的IP 地址。 REMOTE_HOST —— 客户端的主机名。 REMOTE_USER —— 服务器认证后的用户。 REQUEST_METHOD —— 一个字符串,例如"GET" 或"POST"。 SERVER_NAME —— 服务器的主机名。 SERVER_PORT —— 服务器的端口(是一个字符串)。
Request.user:一个AUTH_USER_MODEL 类型的对象,表示当前登陆的用户。若是用户当前没有登陆,user 将设置为django.contrib.auth.models.AnonymousUser 的一个实例。你能够经过is_authenticated() 区分它们,
if request.user.is_authenticated(): # Do something for logged-in users. else: # Do something for anonymous users.
Request.get_host():根据从HTTP_X_FORWARDED_HOST(若是打开USE_X_FORWARDED_HOST)和HTTP_HOST 头部信息返回请求的原始主机。
Request.get_full_path():返回path,若是能够将加上查询字符串。"/music/bands/the_beatles/?print=true"
Request.is_ajax():若是请求是经过XMLHttpRequest(ajax) 发起的,则返回True,
用法:能够将response 看作一个类文件对象
>>> from django.http import HttpResponse >>> response = HttpResponse("Here's the text of the Web page.") >>> response = HttpResponse("Text only, please.", content_type="text/plain")
HttpResponseRedirect:用来重定向的地址(http://www.yahoo.com/search/;/search/)注意!这个响应会返回一个302的HTTP状态码。
HttpResponsePermanentRedirect:与ResponseRedirect同样,可是它会返回一个永久的重定向(HTTP状态码301)而不是一个“found”重定向(状态码302)。
HttpResponseNotModified:构造函数不会有任何的参数,而且不该该向这个响应(response)中加入内容(content)。使用此选项可指定自用户上次请求(状态代码304)以来还没有修改页面。
HttpResponseBadRequest:与HttpResponse的行为相似,可是使用了一个400的状态码。
HttpResponseForbidden:与HttpResponse相似,但使用403状态代码。
HttpResponseNotAllowed:与HttpResponse相似,但使用405状态码。构造函数的第一个参数是必须的:一个容许使用的方法构成的列表(例如,['GET', 'POST'])。
HttpResponseGone:与HttpResponse相似,但使用410状态码。
HttpResponseServerError:与HttpResponse相似,但使用500状态代码。
JsonResponse:
Content-Type 头部设置为application/json。它的第一个参数data,应该为一个dict 实例。若是safe 参数设置为False,它能够是任何可JSON 序列化的对象。布尔参数safe 默认为True。若是设置为False,能够传递任何对象进行序列化(不然,只容许dict 实例)。若是safe 为True,而第一个参数传递的不是dict 对象,将抛出一个TypeError。
>>> from django.http import JsonResponse >>> response = JsonResponse({'foo': 'bar'}) >>> response.content '{"foo": "bar"}' 序列化非字典对象 response = JsonResponse([1, 2, 3], safe=False)