O Netcat falha ao iniciar no modo de escuta

13

Estou usando o sistema CentOS 6.7 (Final) e quando tento executar nc no modo de escuta, ele imprime o seguinte:

# nc -l 1234
nc: Protocol not available

A porta não está vinculada. Eu tentei outros números de porta também. Esse bug parece já ter sido informado: link . Infelizmente não é muito detalhado.

Informações do pacote:

Name        : nc
Arch        : x86_64
Version     : 1.84
Release     : 24.el6

Há algo mais que eu preciso experimentar?

    
por Ilya I 18.10.2015 / 12:13

5 respostas

17

Eu encontrei o mesmo problema. Você pode resolver desta forma:

# Removes the old package
yum erase nc

# Manually downloads the working package from the Official Repository
wget http://vault.centos.org/6.6/os/x86_64/Packages/nc-1.84-22.el6.x86_64.rpm

# Installs the package
rpm -iUv nc-1.84-22.el6.x86_64.rpm

Por favor, note que o pacote é para x86_64 (64 bits). Se você precisar de i386 (32 bits), o correto é:

wget http://vault.centos.org/6.6/os/i386/Packages/nc-1.84-22.el6.i686.rpm
    
por 18.10.2015 / 15:25
10

Esta versão particular do netcat tem um bug. Até que haja uma solução para isso, a única coisa que você pode fazer é fazer o downgrade para uma versão anterior - sudo yum remove nc-1.84-24.el6.x86_64; sudo yum install nc-1.84-22.el6.x86_64 deve fazer o truque.

    
por 18.10.2015 / 13:07
4

Respondendo a pergunta:

  1. SIM, o downgrade é necessário para que o nc possa ouvir. e quanto aos outros comentários:

a) -p não deve ser usado no modo de escuta. de nc manpage:

-l Used to specify that nc should listen for an incoming connection rather than initiate a connection to a remote host. It is an error to use this option in conjunction with the -p, -s, or -z options.

b) downgrade pode ser feito em um passo, yum downgrade comando funciona com o url para o pacote:

$ rpm -q nc
nc-1.84-24.el6.x86_64
$ nc -l 12345 #Although the syntax is correct, the command fails
nc: Protocol not available
$ nc -l -p 12345 #attempt to run with incorrect syntax
usage: nc [-46DdhklnrStUuvzC] [-i interval] [-p source_port]
          [-s source_ip_address] [-T ToS] [-w timeout] [-X proxy_version]
          [-x proxy_address[:port]] [hostname] [port[s]]
$ sudo yum downgrade http://vault.centos.org/6.6/os/x86_64/Packages/nc-1.84-22.el6.x86_64.rpm  #shortcut to downgrade
...
Setting up Downgrade Process
nc-1.84-22.el6.x86_64.rpm                                                              |  57 kB     00:00
Examining /var/tmp/yum-root-Iq4yc7/nc-1.84-22.el6.x86_64.rpm: nc-1.84-22.el6.x86_64
Resolving Dependencies
--> Running transaction check
---> Package nc.x86_64 0:1.84-22.el6 will be a downgrade
---> Package nc.x86_64 0:1.84-24.el6 will be erased
--> Finished Dependency Resolution

Dependencies Resolved

==============================================================================================================
 Package          Arch                 Version                     Repository                            Size
==============================================================================================================
Downgrading:
 nc               x86_64               1.84-22.el6                 /nc-1.84-22.el6.x86_64               109 k

Transaction Summary
==============================================================================================================
Downgrade     1 Package(s)

Total size: 109 k
Is this ok [y/N]: y
...
Removed:
  nc.x86_64 0:1.84-24.el6

Installed:
  nc.x86_64 0:1.84-22.el6

Complete!
$ nc -l -p 12345 #attempt to run with incorrect syntax
usage: nc [-46DdhklnrStUuvzC] [-i interval] [-p source_port]
          [-s source_ip_address] [-T ToS] [-w timeout] [-X proxy_version]
          [-x proxy_address[:port]] [hostname] [port[s]]
$ nc -l 12345 # try to listen again
^C
$#nc successully opens a socket on 12345. had to stop it with ctrl+C
    
por 02.05.2016 / 23:58
0
# nc -l -p 1234

Você pode escutar nessa porta explicitamente usando -p flag:

-p source_port
         Specifies the source port nc should use, subject to privilege restrictions and availability.

O problema foi ao longo das linhas de nc tratar 1234 como a porta destino (apesar de ser executado no modo de escuta) e tentar escutar na porta 0 (que produziu aquela mensagem estranha). Explicitamente passando -p trabalha em torno dele.

    
por 18.10.2015 / 19:27
-3

instale o nmap:

yum install nmap

tente:

ncat -l 1234

    
por 04.01.2016 / 20:01