扫描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 threeIPi">/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 threeIPi">/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

相关推荐
William.csj27 分钟前
Bitvise——进入服务器的快捷方式
运维·服务器
我叫于豆豆吖1 小时前
绕过CDN查找真实IP方法
网络·网络协议·tcp/ip
CS_素锦少年2 小时前
Linux_kernel驱动开发11
linux·运维·驱动开发
结衣结衣.2 小时前
Linux——进程状态
linux·运维·服务器·c语言·笔记·学习
手捧向日葵的话语2 小时前
序列化和反序列化
服务器·网络·计算机网络
li星野2 小时前
面试问题001
linux·开发语言·面试
blaizeer2 小时前
Linux 入门:简单的基础操作
linux·运维·服务器
Eliauk &3 小时前
【docker】通过云服务器安转Docker
java·运维·服务器·spring cloud·docker·容器
网安大师兄3 小时前
如何逼自己自学三个月——网络安全(黑客技术)
网络·sql·学习·安全·web安全·网络安全
GottenZZP4 小时前
如何利用Samba跨平台分享Ubuntu文件夹
linux·运维·ubuntu