版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_28719743/article/details/82715978
安装环境:ubuntu 16.04
安装
apt-get install clang git gcc make libpcap-dev
git clone https://github.com/robertdavidgraham/masscan
cd masscan
make
cd ..
cp masscan/bin/masscan /bin
自我测试
当安装完成是可以测试一下是否安装成功:
make regress
成功显示:
bin/masscan --regress
selftest: success!
扫描
单ip多端口
扫描115.115.115.115 ip 的0-20000端口
masscan 115.115.115.115 -p0-20000
扫描115.115.115.115 ip 的21和80端口
masscan 115.115.115.115 -p21,80
多ip单端口
扫描115.115.0.0-115.115.255.255 ip 的80端口
masscan 115.115.0.0-115.115.255.255 -p80
快速扫描
默认情况下,Masscan扫描速度为每秒100个数据包,这是相当慢的。为了增加这一点,只需提供该-rate选项并指定一个值。
每秒10000个数据包:
masscan 115.115.0.0-115.115.255.255 -p1-65535 --rate 10000
结果保存
masscan 115.115.0.0-115.115.255.255 -p1-65535 --rate 10000 > 1.txt
扫描结果会保存到当前目录下的1.txt里
配置文件扫描
vim masscan.conf
rate = 5000.00
output-format = xml
output-filename = masscan.xml
ports = 1723,27017,6379,9100,80,898,5800,6000
range = 192.168.0.1-192.168.0.255,192.168.10.0-192.168.10.255
masscan -c masscan.conf
详细参数
<ip/range> IP地址范围,有三种有效格式,1、单独的IPv4地址 2、类似"10.0.0.1-10.0.0.233"的范围地址 3、CIDR地址 类似于"0.0.0.0/0",多个目标可以用都好隔开
-p <ports,--ports <ports>> 指定端口进行扫描
--banners 获取banner信息,支持少量的协议
--rate <packets-per-second> 指定发包的速率
-c <filename>, --conf <filename> 读取配置文件进行扫描
--echo 将当前的配置重定向到一个配置文件中
-e <ifname> , --adapter <ifname> 指定用来发包的网卡接口名称
--adapter-ip <ip-address> 指定发包的IP地址
--adapter-port <port> 指定发包的源端口
--adapter-mac <mac-address> 指定发包的源MAC地址
--router-mac <mac address> 指定网关的MAC地址
--exclude <ip/range> IP地址范围黑名单,防止masscan扫描
--excludefile <filename> 指定IP地址范围黑名单文件
--includefile,-iL <filename> 读取一个范围列表进行扫描
--ping 扫描应该包含ICMP回应请求
--append-output 以附加的形式输出到文件
--iflist 列出可用的网络接口,然后退出
--retries 发送重试的次数,以1秒为间隔
--nmap 打印与nmap兼容的相关信息
--http-user-agent <user-agent> 设置user-agent字段的值
--show [open,close] 告诉要显示的端口状态,默认是显示开放端口
--noshow [open,close] 禁用端口状态显示
--pcap <filename> 将接收到的数据包以libpcap格式存储
--regress 运行回归测试,测试扫描器是否正常运行
--ttl <num> 指定传出数据包的TTL值,默认为255
--wait <seconds> 指定发送完包之后的等待时间,默认为10秒
--offline 没有实际的发包,主要用来测试开销
-sL 不执行扫描,主要是生成一个随机地址列表
--readscan <binary-files> 读取从-oB生成的二进制文件,可以转化为XML或者JSON格式.
--connection-timeout <secs> 抓取banners时指定保持TCP连接的最大秒数,默认是30秒。