Tornado request内容

来源:互联网 发布:nemo软件日本语完整版 编辑:程序博客网 时间:2024/05/04 22:27
原文地址

最近学习了用 tornado 编写一段小程序,根据 HTTP header 收集客户端相关信息:是否手机、操作系统、浏览器等信息。

先上代码,简单实用:

[python] view plain copy
print?
  1. import tornado.ioloop  
  2. import tornado.httpserver  
  3. import tornado.options  
  4. import tornado.web  
  5.   
  6. class IndexHandle(tornado.web.RequestHandler):  
  7.     def get(self):  
  8.         self.write("-------method:\n")  
  9.         self.write(self.request.method)  
  10.         self.write("\n-------uri:\n")  
  11.         self.write(self.request.uri)  
  12.         self.write("\n-------path:\n")  
  13.         self.write(self.request.path)  
  14.         self.write("\n-------query:\n")  
  15.         self.write(self.request.query)  
  16.         self.write("\n-------version:\n")  
  17.         self.write(self.request.version)  
  18.         self.write("\n-------headers:\n")  
  19.         self.write(self.request.headers)  
  20.         self.write("\n-------body:\n")  
  21.         self.write(self.request.body)  
  22.         self.write("\n-------remote_ip:\n")  
  23.         self.write(self.request.remote_ip)  
  24.         self.write("\n-------protocol:\n")  
  25.         self.write(self.request.protocol)  
  26.         self.write("\n-------host:\n")  
  27.         self.write(self.request.host)  
  28.         self.write("\n-------arguments:\n")  
  29.         self.write(self.request.arguments)  
  30.         self.write("\n-------query_arguments:\n")  
  31.         self.write(self.request.query_arguments)  
  32.         self.write("\n-------body_arguments:\n")  
  33.         self.write(self.request.body_arguments)  
  34.         self.write("\n-------files:\n")  
  35.         self.write(self.request.files)  
  36.         self.write("\n-------cookies:\n")  
  37.         self.write(self.request.cookies)  
  38.         self.write("\n")  
  39.   
  40. if __name__ == "__main__":  
  41.     tornado.options.parse_command_line()  
  42.     __app__=tornado.web.Application(handlers=[(r'/', IndexHandle)], debug=True)  
  43.     __http_server__=tornado.httpserver.HTTPServer(__app__)  
  44.     __http_server__.listen(8000)  
  45.     tornado.ioloop.IOLoop.instance().start()  

可以看见通过调用self.request获取了tornado.httputil.HTTPServerRequest 对象实例,实例里有headers(信息最丰富的)字典类型的属性,客户的信息就在里面!

以下是我浏览器端的显示结果:


让我们来看一下headers里的信息:
1."Accept-Language": "zh-CN,zh;q=0.8"
     Accept-Language可以说明用户的默认语言设置,它可以通过逗号分隔携带多国语言。第一个是首选的语言,其他语言会携带一个"q"值,来表示用户对这个语言的喜好程度(0-1)。在这里,"zh-CN,zh"是我默认的语言设置,zh-CN是简体中文,zh是中文,优先支持简体中文。"q=0.8"表示我对此语言的喜欢程度很高。
2."Accept-Encoding": "gzip,deflate,sdch"
     大部分现代浏览器会把浏览器所支持的压缩格式(gzip)报告给服务器,这时浏览器就会把压缩过的HTML发送给浏览器,减少文件大小,以节省下载时间和宽带。
3."Connection": "keep-alive"
     表明服务器是有状态服务器(stateful server),什么是有状态服务器呢?简单的理解就是服务器会保留与客户端的连接,不用在每次打开新窗口时都创建连接,同时客户的记录会被保留。比方说你在淘宝买了一件物品放进了购物车,任你怎么切换窗口查看其它物品购物车内都保留了你的物品。而相反,对于无状态服务器(stateless server),用户的行踪服务器都不知道,甚至连用户是否登陆了也不知道,这就需要利用我们常见的Cookie和Session来记录用户状态,用户的每个请求都需要带上自己的Cookie和Session。
4."Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"
     浏览器支持的MIME类型分别是text/html、application/xhtml+xml、application/xml和*/*,优先顺序从左到右排序。MIME(Multipurpose Internet Mail Extensions)多功能Internet邮件扩充服务,是一种多用途网际邮件扩充协议。text/html、application/xhtml+xml、application/xml都是MIME类型,斜杠前面是type(类型),斜杠后面是subject(子类型)。前者范围较大,后者范围更明确,即大类中的小类。text/html表示html文档,application/xhtml+xml表示xhtml文档,application/xml表示xml文档。
5."User-Agent": "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.66 Safari/537.36 LBBROWSER"
    这么多信息简直了!恐怕这是最好用的信息了。User-Agent可以携带浏览器名和版本号、操作系统名和版本号以及默认语言。详细的介绍请参读这里
6."Host": "localhost:8000"
     服务器主机(网站的IP)
7."Cache-Control": "max-age=0"
     "max-age"表明了响应被缓存的有效秒数。允许你的网站被缓存将大大减少下载的时间和宽带,也能提高浏览器的载入速度。
8."If-None-Match": "\"647237d1c3f1f1f586f1e042ec090b9071d0ed46\"
     服务器在response中添加ETag信息(就是那一大串数字),当用户再次请求该资源时,将在request中加入ETag。如果服务器验证请求的ETag没有改变(资源没有更新),将返回一个304状态告诉用户使用本地缓存文件。否则返回200状态和新的资源和ETag。
参考文档:http://www.tornadoweb.org/en/stable/httputil.html#tornado.httputil.HTTPHeaders.get_list
原创粉丝点击