博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于HTTPOXY漏洞的分析说明
阅读量:6678 次
发布时间:2019-06-25

本文共 2035 字,大约阅读时间需要 6 分钟。

好久没写文章了, 博客都长草了,早上起来本来想去上班,一看这么大雨,这要上路了不得堵死啊。

\\

再加上有同学对我昨天转发的微博HTTPOXY漏洞表示不理解,问会不会影响普通应用,于是就写篇文章介绍下,等早高峰过了吧;)…

\\

不过要注意的是,这里我只是介绍PHP这个角度,关于Go和Python等其他角度的,因为我也不是”很”懂,你们还是看原文吧 :)

\\

漏洞原文在,没看懂的一定都是英语没过6级的 :)

\\

这里有一个核心的背景是,长久一来我们习惯了使用一个名为http_proxy的环境变量来设置我们的请求代理,比如在命令行我们经常这么用:

\\
\http_proxy=127.0.0.1:9999 wget http://www.laruence.com/
\\

通过设置一个http_proxy的环境变量,让wget使用代理请求

\\

有据可考的是,这样的设定最初来自1994年的,我猜测大概是当时很多工具是基于这个类库做的,于是就慢慢成了一个既定标准吧.只不过这些应用都要求http_proxy是全部小写的,还不足以造成今天这个漏洞。

\\

但估计是因为环境变量习惯都是大写的原因吧,后来有的类库开始支持大写的http_proxy,比如。

\\

再后来很多的类库,各种语言的,都开始支持这种配置,有的支持大写的,有的支持小写的,还有的都支持。

\\
  • \\t
  • \

包括我们自己,也很有可能在日常的工作中写出如下的代码(我就曾经在写爬虫的时候写过):

\\
\1.  \u0026lt;?php\2.  $http_proxy = getenv(\"HTTP_PROXY\");\3.  if ($http_proxy) {\4.  $context = array(\5.  'http' =\u0026gt; array(\6.  'proxy' =\u0026gt; $http_proxy,\7.  'request_fulluri' =\u0026gt; true,\8.  ),\9.  \10.  );\11.  $s_context = stream_context_create($context);\12.  } else {\13.  $s_context = NULL;\14.  }\15.  $ret = file_get_contents(\"http://www.laruence.com/\", false, $s_context);
\\

那么问题来了,在CGI(RFC 3875)的模式的时候,会把请求中的Header,加上HTTP_前缀,注册为环境变量,所以如果你在Header中发送一个Proxy:xxxxxx,那么PHP就会把他注册为http_proxy环境变量,于是getenv(“HTTP_PROXY”)就变成可被控制的了,那么如果你的所有类似的请求,都会被代理到攻击者想要的地址,之后攻击者就可以伪造,监听,篡改你的请求了…

\\

比如:

\\
\curl -H \"Proxy:127.0.0.1:8000\" http://host.com/httpoxy.php
\\

所以,这个漏洞要影响你,有几个核心前提是:

\\
  • 你的服务会对外请求资源\\t
  • 你的服务使用了http_proxy(大写的)环境变量来代理你的请求(可能是你自己写,或是使用一些有缺陷的类库)\\t
  • 你的服务跑在PHP的CGI模式下(cgi,php-fpm)\

如果你没有满足上面的条件,那么恭喜你,你不受此次漏洞影响 :)。

\\
\

后记:经过微博同学的提醒,我可能把这个问题的影响潜意识的让大家觉得危害不大,但实际上,延伸一下——所有HTTP_开头的环境变量在CGI下都是不可信的,千万不要用于敏感操作,另外一点就是,我深刻的体会过,做安全的同学想象力非常丰富,虽然看似很小的一个点,但到了安全的同学手里,配合他们丰富的想象力,强大的社工能力,也是能做出巨大攻击效果的….

\
\\

那知道了原理修复起来也很简单了,以Nginx为例,在配置中加入:

\\
\fastcgi_param HTTP_PROXY \"\";
\\

所以建议,即使你不受此次漏洞影响,也应该加入这个配置。

\\

而如果你是一个类库的作者,或者你因为什么原因没有办法修改服务配置,那么你就需要在代码中加入对sapi的判断,除非是cli模式,否则永远不要相信http_proxy环境变量。

\\
\1.  \u0026lt;?php\2.  if(php_sapi_name() == 'cli' \u0026amp;\u0026amp; getenv('HTTP_PROXY')) {\3.  //只有CLI模式下, HTTP_PROXY环境变量才是可控的\4.  }
\\

就好比Guzzle的这个修复:

\\

本文转载自鸟哥的博客,原文地址为:

你可能感兴趣的文章
CSS3实现Animation动画
查看>>
WORD神操作!第一个技巧你就傻眼了!
查看>>
js中数组连接concat()
查看>>
HDU 2159 FATE
查看>>
docker-compose 意见搭建Samba文件共享服务
查看>>
Keepalived+Nginx搭建主从高可用并带nginx检测
查看>>
VMware 中如何打开U盘弹出U盘或者移动硬盘的(两种方法)
查看>>
8.10模拟赛
查看>>
走进c++0x,体验不一样的c++
查看>>
tomcat启动报错
查看>>
【转】Centos yum 换源
查看>>
标准字符串函数及 字符串类--数据结构
查看>>
Hibernate内测总结
查看>>
matplotlib.pyplot如何绘制多张子图
查看>>
excel 常用设置
查看>>
[自制操作系统] BMP格式文件读取&图形界面系统框架/应用接口设计
查看>>
js !!条件判断或运算的作用
查看>>
记一次安装Nginx+php-fpm安装后无法解析.php文件,状态码200,但显示空白页
查看>>
BFC
查看>>
C++中++i与i++
查看>>