На странице
Базовое отравление сброса пароля
Лаборатория
Basic password reset poisoning · Practitioner
Решение
Дано
This lab is vulnerable to password reset poisoning. The user `carlos` will carelessly click on any links in emails that he receives. To solve the lab, log in to Carlos's account.
You can log in to your own account using the following credentials: `wiener:peter`. Any emails sent to this account can be read via the email client on the exploit server.
Анализ задания
У PortSwigger есть отдельная заметка «Password reset poisoning». И ещё цикл про «HTTP Host Header attacks». Веб-приложение не знает адрес, на котором оно находится, и поэтому приходится использовать заголовок Host, когда нужно, например, сгенерировать полный URL до сервера. Это актуально как раз для функции сброса пароля, где отправляется ресет-ссылка.
Разведка
Посмотрим запрос на восстановление пароля и попробуем манипулировать заголовком Host.
Отправим запрос на восстановление для своего пользователя.
Теперь отправим ещё раз, но заменим заголовок Host на адрес нашего эксплойт-сервера:
exploit-0a1a00a804fbe14180d3d4d001e100bf.exploit-server.net
Оба запроса прошли — 200. Посмотрим письма:
- Первое — со ссылкой на адрес уязвимого сайта
- Второе — ссылка на адрес нашего эксплойт-сервера
Ок, теперь для отправки письма пользователю carlos заменим поле username на carlos и отправим запрос. Идём смотреть логи доступа.
Вот и запрос от жертвы:
/forgot-password?temp-forgot-password-token=3lc3xbctomlakufr3oftagyorpysgvwo
Переходим по ссылке, задаём любой пароль. Далее логинимся.
Лаба решена!
Ещё в этой категории
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.