request.META里包含了哪些数据?
request.META 是一个Python字典,包含了所有本次HTTP请求的Header信息,比如用户IP地址和用户Agent(通常是浏览器的名称和版本号)。 注意,Header信息的完整列表取决于用户所发送的Header信息和服务器端设置的Header信息。 这个字典中几个常见的键值有:
- HTTP_REFERER,进站前链接网页,如果有的话。 (请注意,它是REFERRER的笔误。)
- HTTP_USER_AGENT,用户浏览器的user-agent字符串,如果有的话。 例如: "Mozilla/5.0 (X11; U; Linux i686; fr-FR; rv:1.8.1.17) Gecko/20080829 Firefox/2.0.0.17" .
- REMOTE_ADDR 客户端IP,如:"12.345.67.89" 。(如果申请是经过代理服务器的话,那么它可能是以逗号分割的多个IP地址,如:"12.345.67.89,23.456.78.90" 。)
- ……
因为 request.META 是一个普通的Python字典,因此当你试图访问一个不存在的键时,会触发一个KeyError异常。 (HTTP header信息是由用户的浏览器所提交的、不应该给予信任的“额外”数据,因此你总是应该好好设计你的应用以便当一个特定的Header数据不存在时,给出一个优雅的回应。)你应该用 try/except 语句,或者用Python字典的 get() 方法来处理这些“可能不存在的键”。
比如我要获得用户的浏览器信息,可以这么设计函数:
1
|
def ua_display(request):
|
2
|
ua = request.META.get( 'HTTP_USER_AGENT' , 'unknown' )
|
3
|
return HttpResponse( "Your browser is %s" % ua)
|
网页输出:
1
|
Your browser is Mozilla / 5.0 (Windows NT 6.1 ; WOW64) AppleWebKit / 537.36 (KHTML, like Gecko) Chrome / 28.0 . 1500.95 Safari / 537.36
|
或者这么写:
1
|
def ua_display_2(request):
|
2
|
try :
|
3
|
ua = request.META[ 'HTTP_USER_AGENT' ]
|
4
|
except KeyError:
|
5
|
ua = 'unknown'
|
6
|
return HttpResponse( "Your browser is %s" % ua)
|
那么 request.META 里面还有什么有用的数据呢?动手写一个简单的view函数来显示 request.META 的所有数据,这样你就知道里面有什么了。
1
|
def display_meta(request):
|
2
|
values = request.META.items()
|
3
|
values.sort()
|
4
|
html = []
|
5
|
for k, v in values:
|
6
|
html.append( '<tr><td>%s</td><td>%s</td></tr>' % (k, v))
|
7
|
return HttpResponse( '<table>%s</table>' % '\n' .join(html))
|
网页输出:
01
|
ALLUSERSPROFILE C:\ProgramData
|
02
|
COMMONPROGRAMFILES C:\Program Files\Common Files
|
03
|
COMSPEC C:\windows\system32\cmd.exe
|
04
|
CONFIGSETROOT C:\windows\ConfigSetRoot
|
05
|
CONTENT_LENGTH
|
06
|
CONTENT_TYPE text / plain
|
07
|
CSRF_COOKIE 8dLJLZyBH801ba24VdzYqJ81b5nqTxh0
|
08
|
DJANGO_SETTINGS_MODULE PythonProject.settings
|
09
|
FP_NO_HOST_CHECK NO
|
10
|
GATEWAY_INTERFACE CGI / 1.1
|
11
|
HOMEDRIVE C:
|
12
|
HTTP_ACCEPT text / html,application / xhtml + xml,application / xml;q = 0.9 , * / * ;q = 0.8
|
13
|
HTTP_ACCEPT_ENCODING gzip,deflate,sdch
|
14
|
HTTP_ACCEPT_LANGUAGE zh - CN,zh;q = 0.8
|
15
|
HTTP_CONNECTION keep - alive
|
16
|
HTTP_COOKIE csrftoken = 8dLJLZyBH801ba24VdzYqJ81b5nqTxh0 ; sessionid = 1rf6hmdw7k0zzsg8q3q1lw2j75gmoood
|
17
|
HTTP_HOST 127.0 . 0.1 : 8000
|
18
|
HTTP_USER_AGENT Mozilla / 5.0 (Windows NT 6.1 ; WOW64) AppleWebKit / 537.36 (KHTML, like Gecko) Chrome / 28.0 . 1500.95 Safari / 537.36
|
19
|
NUMBER_OF_PROCESSORS 4
|
20
|
OS Windows_NT
|
21
|
PATH E:\Python;E:\Python\Scripts;C:\windows\system32;E:\Python
|
22
|
PATHEXT .COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC
|
23
|
PATH_INFO / display_meta /
|
24
|
PROCESSOR_ARCHITECTURE AMD64
|
25
|
PROCESSOR_IDENTIFIER Intel64 Family 6 Model 42 Stepping 7 , GenuineIntel
|
26
|
PROCESSOR_LEVEL 6
|
27
|
PROCESSOR_REVISION 2a07
|
28
|
PROMPT $P$G
|
29
|
PSMODULEPATH C:\windows\system32\WindowsPowerShell\v1. 0 \Modules\
|
30
|
PUBLIC C:\Users\Public
|
31
|
QUERY_STRING
|
32
|
REMOTE_ADDR 127.0 . 0.1
|
33
|
REMOTE_HOST
|
34
|
REQUEST_METHOD GET
|
35
|
RUN_MAIN true
|
36
|
SERVER_PROTOCOL HTTP / 1.1
|
37
|
SERVER_SOFTWARE WSGIServer / 0.1 Python / 2.7 . 5
|
38
|
SESSIONNAME Console
|
39
|
SHIM_MCCOMPAT 0x810000001
|
40
|
WINDOWS_TRACING_FLAGS 3
|
41
|
WINDOWS_TRACING_LOGFILE C:\BVTBin\Tests\installpackage\csilogfile.log
|
42
|
wsgi.errors ', mode ' w' at 0x00000000025C6150 >
|
43
|
wsgi.file_wrapper wsgiref.util.FileWrapper
|
44
|
wsgi. input
|
45
|
wsgi.multiprocess False
|
46
|
wsgi.multithread True
|
47
|
wsgi.run_once False
|
48
|
wsgi.url_scheme http
|
49
|
wsgi.version ( 1 , 0 )
|
可以看到,request.META 包含的数据还是挺多的。用户浏览器信息只是它的其中一项而已。
request.META里包含了哪些数据?相关推荐
- mongodb集群——配置服务器放分片meta信息,说明meta里包含了哪些数据信息
在搭建分片之前,先了解下分片中各个角色的作用. ① 配置服务器.是一个独立的mongod进程,保存集群和分片的元数据,即各分片包含了哪些数据的信息.最先开始建立,启用日志功能.像启动普通的mongod ...
- 如何多次读取request请求里的数据
问题场景 : 我们一般直接获取request请求里的参数进行数据处理,现在想在过滤器里获取请求参数并打印,方便做日志排查. 但是POST请求中的参数是存储在流中的,只能读一次,无法多次读取. 解决办法 ...
- request body 里丢东西了_26. Scrapy 框架-模拟登录-Request、Response
1. Scrapy-Request和Response(请求和响应) Scrapy的Request和Response对象用于爬网网站. 通常,Request对象在爬虫程序中生成并传递到系统,直到它们到达 ...
- 利用commons-fileupload 上传图片(包含表单数据)
在一个表单中包含普通文本数据,另外还有需要上传的图片,那么本程序将图片保存到服务器上的一个图片目录中,文本数据则获取然后输出,查看传输是否正确,后面的处理为涉及. 上传的jsp页面: 最后将信息输出: ...
- 微软从水里捞起了一个数据中心:存储效果更好,故障率仅陆上1/8
萧箫 发自 凹非寺 量子位 报道 | 公众号 QbitAI 还记得两年前,微软将一艘巨大的"潜艇"放入水中的场景吗? 这是一艘满载着数据的潜艇,内有855台服务器,是微软打造的水下 ...
- 8大策略让你对抗机器学习数据集里的不均衡数据
本文转自:http://www.36dsj.com/archives/35137 http://blog.csdn.net/heyongluoyao8/article/details/49408131 ...
- 熟练掌握R语言的Meta分析全流程和不确定性分析,并结合机器学习等方法讲解Meta分析在文献大数据的延伸应用
Meta分析是针对某一科研问题,根据明确的搜索策略.选择筛选文献标准.采用严格的评价方法,对来源不同的研究成果进行收集.合并及定量统计分析的方法,最早出现于"循证医学",现已广泛应 ...
- Django request.META.get()获取header头
Django request.META.get()获取header头 在使用Django过程中需要开发一些API给其他系统使用,为了安全把一些信息放在header头中. 如果header 的key为a ...
- 怎么用ABBYY识别文档里包含的条码
2019独角兽企业重金招聘Python工程师标准>>> 你的文档里包含条码吗?当你需要识别带有条码的文档时该怎么办呢?如果你知道OCR文字识别软件,那这事就好办了.但是,并非所有的O ...
最新文章
- Java微信对账接口返回值解析
- python 单通道转3通道
- STM32F105的时钟配置
- JDK各版本新特性总结
- 二叉树经典题之将二叉树分层打印
- java 接口返回不带双引号_Java入门:基础知识
- Windows快捷键PrtSc截图无法正常使用
- 平板电脑android 管理软件,应用宝HD下载V5.2.0.142 安卓版-Android平板电脑(aPad)专用西西软件下载...
- r语言 断轴 画图_R语言之画图(一)
- 计算1~N之间所有奇数之和(Java)
- Web服务器、应用服务器、数据库服务器之间的关系
- java写一个android程序_【Android开发笔记】3.编写第一个Android程序
- android简易计算器
- 桌面图标文件不能拖动的解决方法
- 视频监控系统由哪几部分组成?(视频监控入门基础-附思维导图)
- 电池中的NTC功能是什么?【转】
- Linux5.8下配置web服务器-入门级指导手册(step by step)
- iOS——UIActivityIndicatorView活动指示器
- 数据管理知识体系指南(第二版)-第三章——数据治理-学习笔记
- 常见的英文单词纠错法...