Netcatの使い方

Netcatは、さまざまなネットワークタスクを実行するために使用する非常に便利なUnixコマンドであり、デバッグを行ったり、動作を学習したりするのに非常に役立ちます。

それはから利用可能ですncコマンド。

次の構文を使用して、任意のネットワークサーバーに接続します。

nc DOMAIN PORT

nc localhost 8000

サーバーに接続すると、メッセージを入力して送信でき、サーバーから返信された返信が表示されます。

単純な1対1のチャットのように、プロトコル(HTTP、FTP、SMTPなど)の形式でアプリケーションレベルの機能に取り組むことができます。

Netcatを使用すると、インターネットを強化するすべてのアプリケーションレベルのプロトコルをシミュレートできます。

Webサーバーに接続して、HTTPプロトコル命令を送信できます。私は自分のウェブサイトに接続することができますnc flaviocopes.com 80、そして私はそれを送ることができます

GET / HTTP/1.1
Host: flaviocopes.com

(the third line is an empty line)

and the server will reply back, with an HTTP/1.1 301 Moved Permanently to https://flaviocopes.com/ response because I force HTTPS.

Here’s a simple example to interface with an “echo” server I built separately, that sends back what we send to it:

Netcat can work with TCP, the default protocol, or UDP.

To use UDP, add the -u flag:

nc -u localhost 8000

You can create a server, too. Use the -l (listen) option to listen on a specific port:

nc -l PORT

and Netcat will print every command received.

Try running the server with nc -l 8001 on one terminal window, and the client nc localhost 8001 on another, then send messages to the server by typing them in the client terminal.

Netcat can also be used for network inspection. You can scan the open ports of a server, in a specific range:

nc -v -z localhost 1-10000

Tip: combine with grep to filter the noise: nc -v -z localhost 1-10000 2>&1 | grep succeeded

(if you’re curious which is the process using a port, run lsof -i :PORT)

You can tell a nc server to send the content of a file to the client that connects:

nc -l PORT < FILENAME

The client connecting with nc DOMAIN PORT will get the content of that file printed out, but it can save the content to a file using nc DOMAIN PORT > FILENAME, resulting in a basic file transfer.

After the file has been served, the server will terminate.

You can wrap that command in a simple Bash shell loop:

while true; do nc -l PORT  < FILENAME; done

That’s the simplest implementation of a Web server:

while true; do nc -l 80  < index.html; done

You can tell the client to send to the server the instructions contained in a file:

nc DOMAIN PORT < FILENAME

Download my free Linux Commands Handbook


More cli tutorials: