概述
Django 使用Request 对象和Response 对象在系统间传递状态。
当请求一个页面时,Django会建立一个包含请求元数据的 HttpRequest 对象。 当Django
加载对应的视图时,HttpRequest 对象将作为视图函数的第一个参数。每个视图会返回一个HttpResponse 对象。
本文档对HttpRequest 和HttpResponse 对象的API 进行说明,这些API 定义在django.http
模块中。
HttpRequest
对象
属性
HttpRequest.scheme #一个字符串,表示请求的方案(通常是http或者https)
HttpRequest.body #一个字节字符串,表示原始HTTP请求的正文
HttpRequest.path #一个字符串,表示请求的页面的完整路径,不包含域名
HttpRequest.methed #一个字符串,表示请求使用的HTTP方法,必须使用大写
HttpRequest.GET #一个类似于字典的对象,包含HTTP GET的所有参数
HttpRequest.POST #一个包含所有给定的HTTP POST参数的类字典对象,提供了包含表单数据的请求
HttpRequest.COOKIES #一个标准的python字典,包含所有cookie,键和值都为字符串
HttpRequest.FILES #一个类似于字典的对象,包含所有的上传文件
HttpRequest.META #一个标准的python字典,包含所有的HTTP头部
HTTP 应用的信息是通过 请求报文 和 响应报文 传递的,关于更多的相关知识,可以阅读《HTTP权威指南》获得。
其中 请求报文 由客户端发送,其中包含和许多的信息,而 django 将这些信息封装成了 HttpRequest 对象,该对象由 HttpRequest 类创建。每一个请求都会生成一个 HttpRequest 对象,django会将这个对象自动传递给响应的视图函数,一般视图函数约定俗成地使用 request 参数承接这个对象。
from django.http.request import HttpRequest
看下这个的方法吧。
方法:
HttpRequest.get_host()#返回请求的原始主机
HttpRequest.get_full_path()#返回path,如果可以将加上查询字符串
HttpRequest.read(size=None)
HttpRequest.readline()
HttpRequest.readlines()
HttpRequest.xreadlines()
HttpRequest.__iter__()
#这几个方法实现类文件的接口用于读取HttpRequest.示例。这使得可以用流的方式读#取进来的请求,一个常见的用例是使用迭代解析器处理大型XML有效载荷,而不是内存#中构造一个完整的XML树。
QueryDict
对象
在HttpRequest 对象中,GET 和POST 属性是django.http.QueryDict
的实例,它是一个自定义的类似字典的类,用来处理同一个键带有多个值。这个类的需求来自某些HTML 表单元素传递多个值给同一个键,
是一个显著的例子。
HttpResponse
对象
与由Django自动创建的HttpRequest 对象相比,HttpResponse
对象由程序员创建.你创建的每个视图负责初始化实例,填充并返回一个 HttpResponse.
HttpResponse 类是在django.http模块中定义的。
用法
传递字符串
典型的应用是传递一个字符串作为页面的内容到HttpResponse 构造函数:
>>>from django.http import HttpResponse
>>>response = HttpResponse("Here is the text of the web page")
>>>response = HttpResponse("Text only,please",content_type="text/plain")
1
2
3
如果你想增量增加内容,你可以将response 看做一个类文件对象
>>>response = HttpResponse()
>>>response.write("
Here is the text of the web page
")
>>>response.write("
here is another paragrah
")
1
2
3
配置 header fields
把它当作一个类似字典的结构,从你的response中设置和移除一个header field。
>>>response = HttpResponse()
>>>reponse['Age'] = 20
>>>del response['Age']