Категория > Новости > HTB Health. Эксплуатируем SSRF от первоначального доступа до захвата хоста - «Новости»
HTB Health. Эксплуатируем SSRF от первоначального доступа до захвата хоста - «Новости»12-01-2023, 00:00. Автор: Pearcy |
Hack The Box. Сложность задачи оценена ее авторами как средняя.warningПодключаться к машинам с HTB рекомендуется только через VPN. Не делай этого с компьютеров, где есть важные для тебя данные, так как ты окажешься в общей сети с другими участниками. РазведкаСканирование портовДобавляем IP-адрес машины в
10.10.11.176 health.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 Он действует в два этапа. На первом производится обычное быстрое сканирование, на втором — более тщательное сканирование, с использованием имеющихся скриптов (опция Результат работы скрипта Скрипт нашел два открытых порта: 22 — служба OpenSSH 7.6p1 и 80 — веб‑сервер Apache 2.4.29. Сразу идем на веб‑сервер. Главная страница сайта http://health.htb Точка входаДавай заполним необходимые поля и отправим данные. В полях URL можно указать адрес своего веб‑сервера. Предварительно запустим его:
python3 -m http.server 8080
Форма отправки данныхЛоги веб‑сервераВ логах веб‑сервера видим два запроса. Первый — это GET-запрос на указанный Monitored URL, а второй — POST-запрос на Payload URL. Так как
from http.server import BaseHTTPRequestHandler, HTTPServer
import logging
class Serv(BaseHTTPRequestHandler):
def do_GET(self):
print("GET " + str(self.path))
print(str(self.headers))
self.send_response(200)
self.send_header('Content-type', 'text/html')
self.end_headers()
def do_POST(self):
content_length = int(self.headers['Content-Length'])
post_data = self.rfile.read(content_length)
print("POST " + str(self.path))
print(str(self.headers))
print(post_data.decode('utf-8'))
self.send_response(200)
self.send_header('Content-type', 'text/html')
self.end_headers()
def log_message(self, format, *args):
return
logging.basicConfig(level=logging.INFO)
httpd = HTTPServer(('', 8080), Serv)
httpd.serve_forever()
httpd.server_close()
Запускаем и делаем повторный запрос. Результат работы сервера Видим, что в данных POST-запроса передается информация об указанных URL, а также пометка
class Serv(BaseHTTPRequestHandler):
def do_GET(self):
print("GET " + str(self.path))
print(str(self.headers))
self.send_response(200)
self.send_header('Content-type', 'text/html')
self.end_headers()
self.wfile.write("<test>RALF_SERVER<test>".encode('utf-8'))
Логи веб‑сервераИ теперь видим, что в данных POST-запроса нам передают наш же ответ на GET-запрос. Значит, нужно проверить, нет ли здесь возможности для эксплуатации SSRF — то есть возможности подделки запросов. Точка опорыSSRFПервым делом я попробовал добраться до файла Предупреждение при запросе файла Перейти обратно к новости |