用bash做个tcp客户端

    日常做后台服务开发,总免不了要写测试客户端。但是tcp客户端写起来其实还是比较罗嗦的,各种错误返回,各种异常判断。。。。而我们通常并不是要写一个健壮的客户端,我们只是要一个能用的客户端来测试服务端是否正确。
    这里给大家介绍一个简单易用的方法:用bash操作socket!很酷,是不是?
 
    man bash,查找tcp关键字,可以看到这么一段内容:
/dev/tcp/host/port
       If host is a valid hostname or Internet address, and port is an integer port number or service  name,  bash attempts to open a TCP connection to the corresponding socket.
    把其中的host和port换成我们要连接的IP和端口,就可以用来建立tcp连接了。如下:
 
exec 3<>/dev/tcp/10.6.221.149/9865
    上面就建立了一个到10.6.221.149:9865的可读可写的socket连接。
    其中3就是指定的连接后的socket fd,由于0、1、2分别被stdin、stdout、stderr占用,所以可用fd最小从3开始。
    ip换成域名其实也是支持的,比如
exec 3<>/dev/tcp/www.xx.com/9865
    注意"<>"前后不要空格,否则会出错。

    发送请求其实很简单,就跟往文件里写数据一样。例如
exec "hello world." >&3
    如果要发HTTP请求,那可以这样:
echo -e "GET /crossdomain.xml HTTP/1.1\r\nHost:www.xx.com\r\n\r\n" >&3
     二进制请求可以这样发:
cat bin_data >&3
    其中bin_data是已经写好的二进制包数据文件。
 
   读取服务器响应跟读文件差不多,可以这样写:
cat <&3
    后台关闭连接以后,cat命令会自动结束。
    如果是读取的二进制内容,可以用hexdump来查看。
hexdump -C -n 31 <&3
    读出来效果如下:

    其中-n是指示hexdump读31个字节就结束。
 
    一个好的编程习惯,建立了连接要记得关闭。
    要关闭上面的socket连接可以这么写:
exec 3>&- # 关闭写,不能再发请求  
exec 3<&- # 关闭读,不能再有返回
    当然,你不关闭其实也不一定有啥大问题,bash脚本执行结束,该连接会自动被关闭。

    下面是我测试用的一个客户端:
#!/bin/sh
exec 3<>/dev/tcp/10.6.221.149/9865
echo "<policy-file-request>" >&3
cat <&3
    瞧,这样的tcp客户端比C语言捣鼓出来的客户端代码少得不是一星半点啊。

    用bash操作udp也差不多的,如法炮制试试吧。
    当然,如果你很能捣鼓,还可以用bash写个服务端试试,捣鼓出来记得把代码分享给我看看。

转载于:https://www.cnblogs.com/hokyhu/archive/2011/09/27/2193489.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值