码迷,mamicode.com
首页 > 其他好文 > 详细

ElasticSearch Groovy远程代码执行POC和exp

时间:2015-03-04 21:09:55      阅读:373      评论:0      收藏:0      [点我收藏+]

标签:



ElasticSearch的这个漏洞的编号是CVE-2015-1427,影响版本为1.3.0-1.3.7以及1.4.0-1.4.2,漏洞成因详见:http://drops.wooyun.org/papers/5107,本文具体探讨一下漏洞利用。

1.2.0版本默认是禁用了脚本执行,如果要使用该功能的话,要在elasticsearch.yml中设置script.disable_dynamic:true

1.3.0版本,开始使用groovysandbox来进行脚本执行,其中使用了白名单机制,限制了可以调用的类和方法等等。

但是因为Java中的反射机制,我们可以通过白名单中的类获取到Runtime,也就造成了远程代码执行漏洞,威力很大。

废话不多说,使用espython客户端进行测试:

技术分享

这里要注意,需要指定一下脚本的类型为groovy。这是因为1.3版本中,MVEL仍然是默认的语言,效果如下:

技术分享

既然是远程代码执行,那攻击面实在是太广阔了,这酸爽。

 1)拒绝服务攻击

技术分享

调用exit即可。

2getshell

技术分享

测试结果,成功返回一个反弹shell

技术分享

如果Linux下,很多服务器都是以root权限运行,提权都省了~~


(3)任意文件读取

获取到输入流之后readLine就能获得回显。

这里不再写出exp程序,因为比较简单,不适用espython api,也可以自己构造一个请求给es服务器。一个query对应一项攻击方法。

批量利用的话,扫IP段的9200然后上攻击代码就行了,希望大家玩的愉快。


ElasticSearch Groovy远程代码执行POC和exp

标签:

原文地址:http://blog.csdn.net/u011721501/article/details/44064523

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!