Reflected XSS into a JS string with angle brackets and double&single quotes HTML-encoded escape
Link portswigger :https://portswigger.net/web-security/cross-site-scripting/contexts/lab-javascript-string-angle-brackets-double-quotes-encoded-single-quotes-escaped
Description:
This lab contains a reflected cross-site scripting vulnerability in the search query tracking functionality where angle brackets and double are HTML encoded and single quotes are escaped.
To solve this lab, perform a cross-site scripting attack that breaks out of the JavaScript string and calls the alert
function.
Proof of concept:
Kirim request pada fitur search dengan input nilai random
Analisa response dan request
Seperti yang dapat dilihat pada response, hasil inputan atau masukan akan dikembalikan pada
blog-header
dan juga pada parameter varSearchTerms
pada tag<script>
Coba untuk merusak JavaScript tersebut. Coba untuk input
"'"
pada searchSetelah menemukan string Anda di DOM, Anda akan melihat bahwa server merespons dengan penambahan garis miring terbalik, ‘\’. Hasil dari penanganan masukan sisi server. Ini adalah ‘escaping’ yang dimaksud judul lab.
Coba untuk input
"\'"
dan analisa response yang diberikanSecara efektif, backslash kita akan lolos dari garis miring terbalik server, sehingga hanya menyisakan tanda kutip tunggal untuk mengakhiri string pencarian kita. Coba masukkan payload
“'-alert(1)”
Tetap tidak berhasil, single quote dan titik koma yang mencegahnya menjadi kode yang valid. Coba tambahkan “//” di akhir payload.
Dapat dilihat, (
';)
telah berhasil dikomentari dan kita dapat melihat pop-up alert
Thanks, Stay Ethical & Happy Hacking! 🍻
Last updated