На странице
Отравление сброса пароля через middleware
Лаборатория
Password reset poisoning via middleware · 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.
Анализ задания
Судя по названию, аналогично предыдущей лабе, только нужно использовать технику использования заголовков X-* для переопределения заголовка Host. В первую очередь обычно проверяют X-Forwarded-Host, а ещё можно:
X-Host
X-Forwarded-Server
X-HTTP-Host-Override
Forwarded
Разведка
Посмотрим функцию сброса пароля.
Отправим запрос на восстановление для своего пользователя.
Попробуем сходу переопределить заголовок Host на адрес нашего эксплойт-сервера.
Никакого ответа, просто Stream closed.
Ок, попробуем X-Forwarded-Host. Добавим к заголовкам:
X-Forwarded-Host: exploit-0a20001104ed604d802011ff017700f1.exploit-server.net
Работает!
Теперь в теле запроса поменяем имя на carlos.
Идём в логи доступа, видим:
/forgot-password?temp-forgot-password-token=j4by8s8k70bbyzg3pj5x6l4d9ymzkl0f
Переходим по ссылке, меняем пароль. Логинимся.
Лаба решена!
Ещё в этой категории
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.