ATT&CKКрасное и синее противостояние с точки зрения:два. Исходящий протокол обнаружения интрасети
ATT&CKКрасное и синее противостояние с точки зрения:два. Исходящий протокол обнаружения интрасети

Когда члены красной команды осуществляют проникновение в интрасеть, они часто сталкиваются со сценариями, когда целевой хост не может получить доступ к сети. Существует множество причин, по которым хост не может получить доступ к сети. Общие причины включают в себя отсутствие настроенного шлюза на целевом хосте и его блокировку. установлен брандмауэр или другое защитное оборудование, позволяющее выходить только определенным протоколам или портам и т. д. Когда мы сталкиваемся с такой ситуацией, мы можем использовать методы, упомянутые в этой главе, чтобы определить, каким протоколам целевой хост разрешает выходить из сети, используя различные методы, включающие этот протокол, и выполнить проникновение в туннель на основе обнаруженной информации о протоколе. При условии, что разрешения целевой системы получены, вы можете использовать различные методы обнаружения протокола, упомянутые ниже, чтобы определить, находится ли она вне сети.

1. Обнаружение протокола TCP/UDP вне сети.

Прежде чем обнаружить протокол TCP/UDP на целевом сервере и выйти из сети, вам необходимо выполнить условие получения упомянутых выше разрешений на управление целевым объектом для проведения этого эксперимента. Топология этой экспериментальной среды показана на рисунке 1-1.

Рисунок 1-1. Экспериментальная топология обнаружения протокола TCP/UDP вне сети.
Рисунок 1-1. Экспериментальная топология обнаружения протокола TCP/UDP вне сети.

1. Инструмент NC обнаруживает исходящую сеть протокола TCP.

1) В соответствии с экспериментальной топологической средой, описанной на рис. 1-1, используйте инструмент nc и команду Telnet, чтобы определить, находится ли протокол TCP вне сети. Сначала давайте познакомимся с инструментом Netcat (NC), который является относительно простым и удобным. очень полезный инструмент, который поддерживает как чтение, так и запись данных через сетевые соединения через TCP и UDP, а также является. Это стабильный инструмент бэкдора, который поддерживает другие программы и драйверы сценариев. Это также мощный инструмент отладки и обнаружения сети, который может устанавливать практически все типы сетевых подключений, необходимые для использования, если вы хотите использовать инструмент NC для обнаружения TCP. протокол Чтобы выйти из сети, сначала мы используем инструмент NC для запуска nc.exe на целевом сервере. -lvp 8888" для прослушивания порта 8888 целевого сервера, как показано на рисунке 1-2. В процессе использования nc для включения соединений мониторинга и выполнения будут инициироваться TCP-запросы и ответы, а также пакеты данных. генерироваться одновременно. Через локальное программное обеспечение анализа трафика Wireshark используется на хосте для захвата пакетов данных, которые инициируют процесс соединения, а затем процесс трехстороннего соединения TCP просматривается через захваченные пакеты данных.

Рис. 1-2. Использование инструмента ЧПУ для включения мониторинга сервера
Рис. 1-2. Использование инструмента ЧПУ для включения мониторинга сервера

2) Используйте инструмент nc на хосте Windows 10, чтобы подключиться к порту 8888 целевого сервера и проверить, находится ли он вне сети. Выполните команду nc.exe -nv 8.130.xxx.xxx 8888" и обнаружите, что соединение установлено успешно и отображается состояние открытого порта, что доказывает, что протокол TCP целевого сервера находится вне сети, как показано на рисунке 1. 3.

Рисунок 1-3 Подключение клиента выполнено успешно
Рисунок 1-3 Подключение клиента выполнено успешно

3) Используя инструмент nc для подключения и обнаружения успешного подключения к сети, вы можете видеть пакеты данных, захваченные с помощью программного обеспечения Wireshark на локальном хосте, анализировать процесс установления соединения между локальным хостом и целевым сервером TCP. протокола и используйте «tcp.port == 8888», отфильтруйте порт TCP, и вы увидите успех трехстороннего установления связи TCP, как показано на рисунке 1-4.

Рис. 1-4 Процесс трехстороннего установления связи TCP
Рис. 1-4 Процесс трехстороннего установления связи TCP

2. Команда Telnet обнаруживает исходящую сеть протокола TCP.

1) Используйте команду Telnet, чтобы определить, находится ли целевой сервер вне сети. Сначала вам нужно использовать инструмент nc на целевом сервере, чтобы открыть порт прослушивания 8888, выполнить команду nc.exe -lvp 8888 и успешно. включите мониторинг целевого сервера, как показано на рисунке 1-5.

Рисунок 1-5 nc включает мониторинг сервера
Рисунок 1-5 nc включает мониторинг сервера

2) Если мониторинг включен, используйте команду Telnet на локальном хосте для подключения к целевому серверу. Выполните команду telnet 8.130.xx.xx 8888, как показано на рис. 1-6, которая доказывает, что соединение установлено успешно, а это означает, что TCP разрешен выход.

Рисунок 1-7 TelnetПодключение клиента выполнено успешно
Рисунок 1-7 TelnetПодключение клиента выполнено успешно

3. Протокол UDP обнаруживает исходящую сеть.

1) Прежде чем определить, находится ли протокол UDP целевого сервера вне сети, вам необходимо загрузить nc на целевой сервер и выполнить команду nc.exe -ulvp 8888" на целевом сервере, чтобы включить мониторинг целевого сервера, как показано на рисунке 1-8, где параметр -u означает, что nc использует протокол udp для передачи данных (nc использует tcp по умолчанию).

Рисунок 1-8. nc использует протокол Udp для мониторинга сервера.
Рисунок 1-8. nc использует протокол Udp для мониторинга сервера.

2) Поскольку UDP — это протокол передачи без установления соединения, между отправителем и получателем нет установления связи. Каждый сегмент UDP будет обрабатываться отдельно. Запустите программу анализа трафика Wireshark на хосте Windows 10, перехватите локальные пакеты трафика и включите мониторинг. Затем используйте инструмент nc, чтобы инициировать соединение на хосте Windows 10. Выполните команду nc.exe -uv 8.130.xx.xx 8888". После того, как тест возвращает ответ, обнаруживается, что отображается сообщение open и соединение установлено успешно, как показано на рис. 1-9.

Рисунок 1-9. Клиент nc успешно подключается по протоколу udp.
Рисунок 1-9. Клиент nc успешно подключается по протоколу udp.

3) Через пакеты данных UDP, захваченные локальным программным обеспечением анализа трафика Wireshark, можно увидеть, что локальный компьютер и целевой сервер обмениваются данными через протокол UDP, подтверждая, что протокол UDP выходит из сети, как показано на рисунке 1. -10.

Рисунок 1-10 Wireshark перехватывает UDP-пакеты
Рисунок 1-10 Wireshark перехватывает UDP-пакеты

2. Обнаружение протокола HTTP/HTTPS вне сети.

При определении того, находится ли протокол Http/Https вне сети на целевом сервере, вы должны выполнить команду в соответствии с типом целевой системы. В разных типах операционных систем используются разные методы обнаружения. Например, в операционной системе Windows вы должны выполнить команду. можно использовать встроенные команды bitsadmin, certutil и т. д. Команда для обнаружения Http или Https вне сети. Операционная система Linux может использовать свои собственные команды curl, wget и другие команды для обнаружения вне сети. Ниже в качестве примеров для обнаружения исходящего трафика http/https используются команды, поставляемые с различными типами операционных систем.

1. Система Windows обнаруживает исходящую сеть HTTP/HTTPS.

(1) Команда Bitsadmin

Команда Bitsadmin — это инструмент командной строки, используемый в операционных системах Windows для создания, загрузки или загрузки заданий, а также отслеживания хода выполнения заданий. Вы можете использовать этот инструмент командной строки, чтобы проверить, можно ли загружать файлы с веб-сайта, чтобы определить, находится ли http или https вне сети. Ниже мы возьмем файл robots.txt официального сайта Baidu в качестве примера для демонстрации и использования команды Bitsadmin. загрузить файл robots из каталога официального сайта Baidu и сохранить его в файл robots.txt на локальном диске C.

Выполните команду bitsadmin /rawreturn /transfer down «https://www.baidu.com/robots.txt» c:\robots.txt». На данный момент файл robots.txt успешно загружен в каталог диска C. Затем используйте команду «type C:\robots.txt» для чтения, просмотра и проверки ее существования. Если все в порядке, это доказывает, что обнаружение сети прошло успешно, как показано на рисунке 1-11.

Рисунок 1-11 BitsadminЗаказ успешно обнаружил сеть
Рисунок 1-11 BitsadminЗаказ успешно обнаружил сеть

(2) Уверенная команда

Команда Certui — это инструмент командной строки для загрузки файлов в операционной системе Windows. Ее можно использовать для установки служб сертификации, создания дампа и отображения информации о конфигурации центра сертификации (CA), настройки служб сертификации, резервного копирования и восстановления компонентов CA, а также проверки сертификатов. , пары ключей и цепочки сертификатов.

Далее мы по-прежнему возьмем файл robots.txt на веб-сайте Baidu в качестве примера и используем команду Certuil для выполнения certutil -urlcache -split -f https://www.baidu.com/robots.txt. c:\robots.txt» Сохраните файл robots.txt на веб-сайте Baidu в локальном каталоге диска C. В ходе проверки обнаружено, что файл robots.txt существует, что доказывает, что протокол http/https отсутствует в сети. , как показано на рисунке 1-12.

Рисунок 1-12 certuiЗаказ успешно обнаружил сеть
Рисунок 1-12 certuiЗаказ успешно обнаружил сеть

2. Система Linux обнаруживает исходящую сеть HTTP/HTTPS.

(1) Команда скручивания

Curl — это инструмент командной строки, поставляемый с Linux. Он используется для передачи данных с сервера или на него. При использовании Curl для тестирования сети использовать команду очень просто. проверено Curl.

На примере веб-сайта Baidu команда «curl http://www.baidu.com» успешно выполняется и отображается следующий HTML-код внешнего интерфейса, доказывающий, что протокол http/https находится вне сети, как показано на рисунке. на рисунке 1-13.

Рисунок 1-13 CurlЗаказ успешно обнаружил сетевое соединение
Рисунок 1-13 CurlЗаказ успешно обнаружил сетевое соединение

(2) Команда Wget

Wget — следующий инструмент загрузки командной строки для Linux. Он поддерживает протоколы http и ftp, а также несколько режимов загрузки. Обычно он используется для пакетной загрузки файлов.

Используйте Wget в Linux для обнаружения исходящей сети. Метод использования тот же, что и в предыдущей демонстрации. Используйте инструмент wget для выполнения команды wget http://www.baidu.com/robots.txt для загрузки файла robots.txt. в корневом каталоге Baidu. Протокол обнаружения успешно работает, как показано на рисунке 1-14.

Рисунок 1-14 wgetЗаказ успешно обнаружил сеть
Рисунок 1-14 wgetЗаказ успешно обнаружил сеть

3. Обнаружение протокола ICMP вне сети.

ICMP (Протокол управляющих сообщений Интернета) — это протокол, ориентированный на отсутствие установления соединения, который принадлежит сетевому уровню и используется для обнаружения сбоев сетевой связи и реализации отслеживания каналов. Когда нам нужно определить, находится ли протокол ICMP вне сети, мы можем обнаружить это с помощью команд Ping и Tracert. Ниже эти две команды используются в качестве примеров для демонстрации.

1. Система Windows обнаруживает исходящую сеть протокола ICMP.

(1) Команда Ping

Команда Ping, наверное, всем знакома. Команда Ping часто используется для проверки сетевого подключения. Поскольку эта команда реализована на основе протокола ICMP, Ping является наиболее часто используемой командой при исходящем тестировании ICMP. com, вы можете увидеть возвращаемую информацию, как показано на рисунке 1-15, которая доказывает, что обнаружение исходящих сообщений протокола ICMP прошло успешно.

Рисунок 1-15 Ping Заказ успешно обнаружил сеть
Рисунок 1-15 Ping Заказ успешно обнаружил сеть

(2) Команда трассировки

Команда Tracert — это команда, используемая для отслеживания маршрутов в Windows. Она основана на протоколе ICMP. При исходящем тесте ICMP вам нужно использовать команду Tracert только для отслеживания целевого адреса. В качестве примера выполните команду Tracert Baidu. .com, чтобы получить следующее: Возвращаемая информация, показанная на рис. 1-16, доказывает, что сетевое соединение установлено успешно.

Рисунок 1-16 TracertЗаказ успешно обнаружил сеть
Рисунок 1-16 TracertЗаказ успешно обнаружил сеть

2. Система Linux обнаруживает исходящую сеть протокола ICMP.

Обычно вы можете использовать команду ping для обнаружения протокола ICMP вне сети в системе Linux. Это похоже на вышеупомянутый эксперимент с работой системы Windows, но в системе Linux необходимо использовать -c для указания количества раз. Команда ping в системе Windows автоматически прекратится после четвертого выполнения. В системе Linux она не остановится автоматически. Выполните команду ping -c 4 baidu.com, и результаты, показанные на рис. 1-17, докажут, что сеть успешно обнаружена.

Рисунок 1-17 PingЗаказ успешно обнаружил сеть
Рисунок 1-17 PingЗаказ успешно обнаружил сеть

4. Обнаружение протокола DNS вне сети.

DNS (система доменных имен) — это система разрешения доменных имен, которая может сопоставлять доменные имена соответствующим IP-адресам доступа. Далее мы возьмем встроенные команды системы в качестве примера, чтобы продемонстрировать обнаружение протокола DNS вне сети.

1. Система Windows обнаруживает исходящую сеть протокола DNS.

Чтобы проверить исходящую сеть протокола DNS в системе Windows, вы можете использовать команду Nslookup. Это инструмент командной строки управления сетью, который можно использовать для запроса доменных имен DNS и разрешения IP. nslookup имеет два режима работы: интерактивный и неинтерактивный. Здесь вы можете использовать неинтерактивный режим. Выполните команду nslookup baidu.com, и будет возвращен результат ответа, подтверждающий успешность сетевого подключения, как показано на рисунке 1-18.

Рисунок 1-18 NslookupЗаказ обнаруживает отсутствие сети
Рисунок 1-18 NslookupЗаказ обнаруживает отсутствие сети

2. Система Linux обнаруживает исходящую сеть протокола DNS.

(1) Команда копать

Команда Dig используется для запроса DNS в операционной системе Linux. Инструмент запросов сервера доменных имен может запрашивать информацию, связанную с записями NS, A и MX, в соответствии с протоколом DNS. Выполните команду dig @8.8.8.8 www.baidu.com, укажите здесь DNS-сервер, 8.8.8.8 — DNS-сервер Google. Результат ответа возвращается для подтверждения успешного подключения к сети, как показано на рисунке 1-19.

Рисунок 1-19 DigЗаказ успешно обнаружил сеть
Рисунок 1-19 DigЗаказ успешно обнаружил сеть

(2) Команда Nslookup

В системах Linux вы также можете использовать команду nslookup для обнаружения протокола DNS системы вне сети. Метод тот же, что и в системе Windows. Выполните команду nslookup baidu.com. После выполнения возвращенный результат подтверждает, что сеть успешно подключена, как показано на рисунке 1-20.

Рисунок 1-20 nslookupЗаказ успешно обнаружил сеть
Рисунок 1-20 nslookupЗаказ успешно обнаружил сеть

5. Краткое содержание этой статьи

Благодаря постоянному обновлению и усовершенствованию туннельной технологии все больше и больше злоумышленников используют туннельную технологию для атак на корпоративные интрасети. В этой статье анализируется разделение технологии туннельного сокрытия по нескольким направлениям и объясняется туннельная технология в целом, включая краткое изложение базовых знаний. . И использование соответствующих туннельных инструментов, а также методов обнаружения и защиты технологии маскировки туннелей, а также продемонстрировало ряд реальных распространенных сценариев туннелирования в большом количестве случаев. Например, мы использовали несколько протоколов для достижения проникновения в туннель и порта после получения системы. разрешения, проникновение в интранет, короче говоря, я надеюсь, что этот контент будет полезен читателям.


Я участвую в третьем этапе специального тренировочного лагеря Tencent Technology Creation 2023 с эссе, получившими приз, и сформирую команду, которая разделит приз!

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose