XXE in Public Transport Ticketing Mobile APP
This finding was an another private bug bounty program. The scope of the target was a ticketing android app (Prod). This app was a major Public Transport Ticketing app based out of Germany.
After logging into the android app and going through the account settings, I came across a “Change my data” option.
data:image/s3,"s3://crabby-images/6c5ec/6c5ec555dd577c242d7f5f2b0b5cd52d5c1206e6" alt=""
In the next screen, I have to modify my personal data
data:image/s3,"s3://crabby-images/5c1a0/5c1a0fc2e01ba07e584e91d332ef21bfa6857a24" alt=""
While saving the data, I found the following request was sent to the server
data:image/s3,"s3://crabby-images/f93ba/f93ba53949043a3aee2070d463ac7cb569647648" alt=""
The request format was like 062.6.26#{some long data}.
This looks interesting. Next, I selected {some long data} and sent it to the decoder. I tried decoding it and found it was base64. The decoded data was an XML as shown in the below image
data:image/s3,"s3://crabby-images/8660a/8660adb21d6ed9d931effcfdfb9ac4ee632353b7" alt=""
Great, next I included the following XXE payload
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE aa[<!ELEMENT bb ANY><!ENTITY xxe SYSTEM "file:///etc/passwd">]>
and called the defined entity &xxe;
from the body as shown in the following image:
data:image/s3,"s3://crabby-images/bef7a/bef7aaa7dcdef09bd9d0cd918313c1609b7e334b" alt=""
Now, all that I needed to do was to encode the whole payload back to base64 format.
data:image/s3,"s3://crabby-images/746ac/746ac6be2669aa2efd9151fee15ab050d4e18850" alt=""
Finally, I replaced the payload in the original request and forwarded the request to the server. And, bang! I got the content of /etc/passwd
data:image/s3,"s3://crabby-images/0b288/0b288d47a5133932d67369c53a61e5b8d07272f9" alt=""
Since the application was using java, you can even list the directories by using the following payload
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE aa[<!ELEMENT bb ANY><!ENTITY xxe SYSTEM "file://">]>
data:image/s3,"s3://crabby-images/c7e44/c7e4473e46693bd0afd8b503411581db02ec2933" alt=""
I was mainly looking for SSH private keys but out of curiosity, I tried to fetch /etc/shadow
(feeling lucky :D). And, to my surprise, I got it (this is a rare case). The response makes it clear that it’s running as root.
data:image/s3,"s3://crabby-images/05c7b/05c7b2450654d9037b2d92337f490785493ab27a" alt=""
I also found, the SSH private keys are too available in the /home/user/.ssh/
directory. This means we can also perform a full RCE on the system but full escalation wasn’t allowed in the program. So I didn’t attempt that and stopped my testing till here and reported the same.
data:image/s3,"s3://crabby-images/9efb9/9efb9030befce664401bd58c4f2ec9b7123a2b38" alt=""
That’s it for now. See you in the next article. Stay Curious ✌🏻
Thank you Bhavuk Jain , Kainat Kamal and jinen for proofreading.