[root@bowen ~]# more chkhostport.sh
#! /bin/bash
for i in {1..65536}; do if echo &>/dev/null > /dev/tcp/127.0.0.1/${i} ;then echo -e "The local server port 033[31;40m${i}033[0m is open"; fi
; done
echo
ping -c 3 -i 0.2 -W 3 $1 &> /dev/null
if [ $? -eq 0 ]
then
echo "Host $1 is On-line."
echo
for i in {1...65536};do if nmap -sT $1|grep tcp|awk -F '/' '{print $1}'>/dev/null;then echo -e "The remote server $1 port `nmap $1|grep t
cp|awk -F '/' '{print $1}'` is open";fi;done
else
echo "Host $1 is Off-line."
fi
脚本解释:
1.echo > /dev/tcp/host/port 为0,表示端口是连通的,可以新建一个socket。/dev/[tcp|udp]/host/port只要读取或者写入这个文件,相当于系统会尝试连接:host这台机器对应的port端口。如果主机以及端口存在,就建立一个socket连接。会在/proc/self/fd目录下面,有对应的文件出现。
2.for循环的格式是for...;do....;done
3. 是一个制表符,表示在文本框里输入信息时,敲了一下Tab键。
4.echo -e "033[31;40m something here 033[0m"; echo -e "033[背景颜色;字体颜色m字符串033[0m" 其中,31代表字体颜色是红色,40代表背景颜色是黑色。
5.echo 可以直接输出一个空行。
6.操作>/dev/null 可以把执行结果放入空设备无底洞。
7.nmap -sT $1|grep tcp|awk -F '/' '{print $1}' 可以输出开放的TCP端口号。
8.nmap -sU 192.168.163.145|grep udp|awk -F '/' '{print $1}' 可以输出开放的UDP端口号。