使用Bash进行Netcat TCP编程

Rin*_*ngo 6 linux bash tcp netcat

我正在尝试使用严格的bash脚本来进行一些基本的TCP客户端通信.我有netcat可供我使用,所以到目前为止我已经编写了这个循环:

nc 10.0.0.104 4646 | while read line
do
   if [ "$line" == '{"cmd": 1}' ]
   then
      # Send text back to the TCP server
      echo '{"error": 0}'
   fi
done
Run Code Online (Sandbox Code Playgroud)

该脚本可以成功连接到我正在使用的服务器应用程序,但我很难搞清楚如何将文本发送回netcat进程.

gni*_*urf 5

使用Bash?4可以使用coproc

#!/bin/bash

coproc nc { nc 10.0.0.104 4646; }

while [[ $nc_PID ]] && IFS= read -r -u${nc[0]} line; do
    case $line in
        ('{"cmd": 1}')
            printf >&${nc[1]} '%s\n' '{"error": 0}'
            ;;
        (*)
            printf >&2 '%s\n' "Received line:" "$line"
            ;;
    esac
done
Run Code Online (Sandbox Code Playgroud)

这样可以避免使用临时fifos。没有coproc,我猜剩下的唯一选择是显式使用fifos。这是一个例子:

#!/bin/bash

mkfifo fifo_in

while IFS= read -r line; do
    case $line in
        ('{"cmd": 1}')
            printf '%s\n' '{"error": 0}'
            ;;
        (*)
            printf >&2 '%s\n' "Received line:" "$line"
            ;;
    esac
done < <(nc 10.0.0.104 4646 < fifo_in) > fifo_in
Run Code Online (Sandbox Code Playgroud)

为此,您将必须管理fifo的创建和删除:您需要使用创建一个临时目录mktemp,在其中创建fifo,然后trap编写脚本,以便在退出时清除所有内容。


/dev/tcp

如果您的Bash已通过网络重定向支持进行编译,则可以完全摆脱ncfifos和协同处理:

#!/bin/bash

# open TCP connection, available on file descriptor 3
exec 3<> /dev/tcp/10.0.0.104/4646 || exit

while IFS= read -r -u3 line; do
    case $line in
        ('{"cmd": 1}')
            printf >&3 '%s\n' '{"error": 0}'
            ;;
        (*)
            printf >&2 '%s\n' "Received line:" "$line"
            ;;
    esac
done
Run Code Online (Sandbox Code Playgroud)

这很可能是最甜蜜的解决方案!