Перейти к основному содержанию

Linux — nc вместо telnet

Linux 2

Может так случиться, что на сервере Linux может не оказаться нашей любимой команды telnet. Как тогда проверить доступность порта на удалённой машине? На помощь приходит команда nc.

Команда nc (netcat) служит для передачи и получения данных посредством протоколов TCP и UDP. Богатым функционалом она не отличается, но основные необходимые операции выполнить можно.

Проверка доступности TCP порта:

nc -vz 10.10.12.13 8080

nc

Список параметров, в зависимости от версии netcat, может отличаться:

nc --help

nc

nc

Некоторые параметры:

  • -6 – использовать протокол IPv6. По умолчанию используется параметр -4 и IPv4 соответственно
  • -h – справка
  • -i задержка в секундах
  • -l – режим прослушивания
  • -N – закрыть соединение при достижении конца файла при его отправке
  • -n – Работать с IP-адресами напрямую, не используя DNS, отключить поиск портов
  • -P имя_пользователя – указать имя пользователя для подключения к прокси
  • -x адрес:порт – указать адрес и порт для подключения к прокси
  • -p порт – номер порта
  • -U – использовать сокет домена UNIX (для межпроцессного взаимодействия)
  • -u – использовать протокол UDP, по умолчанию используется TСP
  • -v – подробный режим
  • -W количество_пакетов – закрыть соединение после получения определённого количества пакетов
  • -w таймер – таймер в секундах
  • -z – отключить отправку данных

Ещё примеры (трюки nc)

Проверка доступности TCP порта:

nc -vz 10.10.12.13 8080

Проверка доступности диапазона TCP портов:

nc -vz 10.10.12.13 1-1000 2>&1 | grep succeeded

Сканирование UDP портов:

nc -vzu 10.10.12.13 1-1000

Прослушать UDP порт на получателе:

nc -nlv 8080

Использование nc в качестве чата на открытом порту:

# на компьютере 1
nc -lp 8080

# на компьютере 2
nc 0.0.0.0 8080

Обмен файлами:

# на компьютере 1
nc -l 8080 > paste.txt

# на компьютере 2
nc -N 0.0.0.0 8080 < copy.txt

Страница веб-сервера, можно использовать в качестве заглушки:

while true; do echo -e "HTTP/1.1 200 OK\n\n$(cat index.html)" | nc -l -w 1 -p 80; done

Использование nc в качестве терминала:

# на компьютере 1
nc -lvnp 8080

# на компьютере 2
rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|sh -i 2>&1|nc 0.0.0.0 8080 >/tmp/f

Теги

 

Похожие материалы

Windows 10 — генерация DKIM ключей с помощью подсистемы Linux

Воспользуемся подсистемой Linux и сгенерируем DKIM ключи в ОС Windows 10. DomainKeys Identified Mail (DKIM) — метод e-mail аутентификации, разработанный для обнаружения подделывания сообщений, пересылаемых по email. Метод дает возможность получателю проверить, что письмо действительно было отправлено с заявленного домена.