扫描IP开放端口该脚本用于对特定目标主机进行常见端口扫描(加载端口字典)或者指定端口扫描,判断目标主机开

扫描IP开放端口该脚本用于对特定目标主机进行常见端口扫描(加载端口字典)或者指定端口扫描,判断目标主机开

#/bin/bash

#该脚本用于对特定目标主机进行常见端口扫描(加载端口字典)或者指定端口扫描,判断目标主机开放来哪些端口

#用telnet方式

IP=$1

#IP=119.254.3.28

#获得IP的前三位

threeIP=(echo IP |awk -F. '{print 1"."2"."$3"."}')

#获得IP的第四位

endIP=(echo IP | awk -F. '{print $4}')

if $1

then

if $2

then

#IP的第四位为0表明是一个网段,对整个网段进行特定端口的扫描,发现哪个主机开放特定端口

if $endIP -eq 0

then

for ((i=128;i<=140;i++))

do

(sleep 1;)|telnet threeIPi 2 2\>\&1 \|grep "Connected to threeIP$i">/dev/null

if $? -eq 0

then

echo "主机threeIPi开放$2端口!"

else

echo "主机threeIPi的$2端口关闭!"

fi

done

else

#IP的第四位不为0,说明是单个IP,对单个IP进行特定端口扫描

(sleep 1;)|telnet 1 2 2>&1 |grep "Connected to $1">/dev/null

if $? -eq 0

then

echo "主机1开放2端口!"

else

echo "主机1的2端口关闭!"

fi

fi

else

#脚本只有一个IP参数,根据IP的第四位是否为0来判断是否为网段,因为没有端口参数,扫描默认端口

if $endIP -eq 0

then

for ((i=128;i<=130;i++))

do

for port in $(cat defaultport.txt)

do

(sleep 1;)|telnet threeIPi port 2\>\&1 \|grep "Connected to threeIP$i">/dev/null

if $? -eq 0

then

echo "主机threeIPi开放$port端口!" > /home/peter/Ip.txt

else

echo "主机threeIPi的$port端口关闭!"

fi

done

done

else

#脚本只有IP一个参数,没有端口参数,加载端口字典扫描默认端口

for ((i=1;i<=1024;i++))

do

#与目标主机的特定端口只通信1秒,根据返回的数据来判断目标是否开放特定端口

(sleep 1;)|telnet 1 i 2>&1 |grep "Connected to $1">/dev/null

if $? -eq 0

then

echo "主机1开放i端口!" >> /home/peter/Ip.txt

else

echo "主机1的i端口关闭!"

fi

done

fi

fi

else

echo "*******************************************

该脚本的用法示例:

$0 192.168.1.1(扫描默认端口)

$0 192.168.1.1 portx(扫描指定IP指定端口portx)

$0 192.168.1.0(扫描指定网段,扫描默认端口)

$0 192.168.1.0 portx(扫描指定网段指定端口portx)

******************************************** "

fi

相关推荐
zzzzzz3101 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode1 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
A小辣椒3 天前
TShark:Wireshark CLI 功能
linux
A小辣椒3 天前
TShark:基础知识
linux
AlfredZhao3 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao4 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334664 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
猪脚踏浪4 天前
linux 拷贝文件或目录到指定的位置
linux
大树885 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠5 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql