我正在尝试使用严格的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
该脚本可以成功连接到我正在使用的服务器应用程序,但我很难搞清楚如何将文本发送回netcat进程.
最佳答案
使用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
这避免了使用临时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
为此,您必须管理fifo的创建和删除:您需要使用mktemp创建一个临时目录,在那里创建fifo,然后捕获您的脚本,以便在退出时清除所有内容.
的/ dev / TCP
如果您的Bash已经使用net redirections支持进行编译,那么您可以完全删除nc以及fifos和coprocesses:
#!/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
这很可能是最甜蜜的解决方案!