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进程.
使用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)
这很可能是最甜蜜的解决方案!
| 归档时间: |
|
| 查看次数: |
1382 次 |
| 最近记录: |