| Категория >  Новости > HTB Late. Эксплуатируем инъекцию шаблонов в сервисе обработки изображений - «Новости» HTB Late. Эксплуатируем инъекцию шаблонов в сервисе обработки изображений - «Новости»3-08-2022, 00:00. Автор: Administrator | 
| Hack The Box. warningПодключаться к машинам с HTB рекомендуется только через VPN. Не делай этого с компьютеров, где есть важные для тебя данные, так как ты окажешься в общей сети с другими участниками. РазведкаСканирование портовДобавляем IP-адрес машины в  10.10.11.156   late.htbИ запускаем сканирование портов. Справка: сканирование портовСканирование портов — стандартный первый шаг при любой атаке. Он позволяет атакующему узнать, какие службы на хосте принимают соединение. На основе этой информации выбирается следующий шаг к получению точки входа. Наиболее известный инструмент для сканирования — это Nmap. Улучшить результаты его работы ты можешь при помощи следующего скрипта. ports=$(nmap -p- --min-rate=500 $1 | grep^[0-9] | cut -d '/' -f 1 | tr 'n' ',' | sed s/,$//)nmap -p$ports -A $1Он действует в два этапа. На первом производится обычное быстрое сканирование, на втором — более тщательное сканирование, с использованием имеющихся скриптов (опция  Результат работы скрипта Находим всего два открытых порта: 
 Брутить SSH смысла нет, поэтому начинаем исследование с веб‑сервера. Справка: брутфорс учетокПоскольку вначале у нас нет учетных данных, нет и смысла изучать службы, которые всегда требуют авторизации (например, SSH). Единственное, что мы можем делать здесь, — это перебирать пароли брутфорсом, но машины с HTB почти всегда можно пройти по‑другому. В жизни таких вариантов может не быть, к тому же есть шансы подобрать пароль или получить его при помощи социальной инженерии. Заглянем на сайт через браузер. Главная страница сайта http://late.htb Точка входаНа сайте видим всего две страницы: Home (текущая) и Contact. Попробуем поискать скрытый контент. Справка: сканирование веба c ffufОдно из первых действий при тестировании безопасности веб‑приложения — это сканирование методом перебора каталогов, чтобы найти скрытую информацию и недоступные обычным посетителям функции. Для этого можно использовать программы вроде dirsearch и DIRB. Я предпочитаю легкий и очень быстрый ffuf. При запуске указываем следующие параметры: 
 Запускаем ffuf: ffuf -u 'http://late.htb/FUZZ' -t 256 -wdirectory_2.3_medium_lowercase.txtРезультат сканирования каталогов с помощью ffufСнова ничего интересного. Тогда перейдем к сканированию файлов HTML (ведь нас встретили именно такие статические страницы): ffuf -u 'http://late.htb/FUZZ.html' -t 256 -wdirectory_2.3_medium_lowercase.txtРезультат сканирования HTML-файлов с помощью ffufИ снова ничего нового. Тогда я решил просмотреть исходники страниц и сразу обнаружил в тексте ссылку, ведущую на другой поддомен! Ссылка в тексте  Найденный поддомен добавим в файл  10.10.11.156 late.htb images.late.htbГлавная страница сайта http://images.late.htbНас встречает преобразователь изображений в текст, написанный с использованием Flask, а это значит, что нужно сразу проверить наличие уязвимостей SSTI. Точка опорыЯ решил отправить первое попавшееся под руку изображение, чтобы посмотреть, как работает этот конвертер, и в ответ получил запрос на сохранение файла. Файл содержал весь текст с отправленного изображения, заключенный в тег  Отправленное изображение и скачанный файл От SSTI к RCEРаз мы можем управлять кодом на странице, попробуем проэксплуатировать SSTI. Справка: server-side template injectionServer-side template injection (SSTI), или инъекция шаблонов на стороне сервера, — это механизм атаки, при котором злоумышленник внедряет в шаблон вредоносный код. Шаблоны нужны веб‑разработчикам, чтобы можно было настраивать внешний вид сайта только в одном месте и затем не копировать вручную. По сути, шаблон — это документ HTML, где в нужных местах отмечены переменные и команды, которые при генерации итоговой страницы будут заменены данными. В том числе это могут быть и данные, полученные от посетителя сайта. Атака затрагивает момент, когда присланная информация объединяется с шаблоном. Злоумышленник формирует строку таким образом, чтобы она не просто подставилась в шаблон, но была интерпретирована как код. Если это возможно, то он добавит свои директивы, с помощью которых выполнит эксфильтрацию данных или даже захват веб‑сервера. Перейти обратно к новости |