class HttpRequest[source]

属性

所有的属性都是只读的,除非另有说明

HttpRequest.scheme

字符串(http/https)表示http还是https请求

HttpRequest.body

原始的http请求正文

也可以像文件一样读他,看 HttpRequest.read().

HttpRequest.path

完整的请求路径,不包括域

例: "/music/bands/the_beatles/"

HttpRequest.path_info

在某些情况下,路径被分割成脚本前缀和路径,这样可以使部署和测试更方便

例如脚本前缀为"/minfo", 路径为"/minfo/music/bands/the_beatles/" path_info为 "/music/bands/the_beatles/"

HttpRequest.method

字符串(GET/POST)表示GET还是POST请求

if request.method == 'GET':
    do_something()
elif request.method == 'POST':
    do_something_else()
常用方法
HttpRequest.encoding

一个字符串,用于解码的当前编码的表单提交的数据(或没有,就使用thedefault_charset)。在访问表单数据时,可以使用此属性来更改所用的编码。如果你知道表格数据不是default_charset编码。随后的任何属性的访问(如阅读从GET或POST)将使用新的encodingvalue。

HttpRequest.GET

GET请求对象,详细查看 QueryDict 

HttpRequest.POST

POST请求对象,详细查看 QueryDict

注意: POST不包含文件上传,请看 FILES.

HttpRequest.COOKIES

客户端cookies信息,字典类型

HttpRequest.FILES

一个包含所有文件对象的字典. key是<inputtype="file" name="" />中name的值,没一个value是一个上传的文件对象,请查看 UploadedFile.

参看 Managing files 获取更多信息

如果要上传文件需要在 <form> 标签中添加 enctype="multipart/form-data",不然收到的是一个空值

HttpRequest.META

请求头信息

例:

  • CONTENT_LENGTH 请求体当作一个字符串的总长度。
  • CONTENT_TYPE 请求体的MIME类型。
  • HTTP_ACCEPT 可以接受的内容类型的响应。
  • HTTP_ACCEPT_ENCODING 接受编码的响应。
  • HTTP_ACCEPT_LANGUAGE 接受语言的反应。
  • HTTP_HOST 客户端请求时用的服务端地址
  • HTTP_REFERER 参考页面
  • HTTP_USER_AGENT 客户端的标志信息
  • QUERY_STRING 一对一的查询字符串
  • REMOTE_ADDR 客户端IP
  • REMOTE_HOST 客户端主机名
  • REMOTE_USER 客服端的身份信息
  • REQUEST_METHOD 请求方式
  • SERVER_NAME 服务器主机名
  • SERVER_PORT 服务端开放的端口

 

HttpRequest.resolver_match

An instance of ResolverMatch representing the resolved url. This attribute is only set after url resolving took place, which means it’s available in all views but not in middleware methods which are executed before url resolving takes place (like process_request, you can use process_view instead).

相关文章: