本文主要是介绍主机探测和端口扫描的流量隐藏问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Nmap
- 确认Nmap版本:Nmap版本必须在7.70以上,否则可能没有这个功能;
–data-length
选项用于向扫描数据包中添加额外的空数据。
–data-offset
选项用于在数据包中插入空白数据区,以设置数据偏移量。
例:
nmap --data-length 100 --data-offset 50 192.168.1.1
–mtu
nmap 的 --mtu 选项允许你指定数据包的 MTU 大小。如果设置的 MTU 大于 1500 字节,数据包将会被分片传输。
例:nmap --mtu 1600 192.168.1.1
–source-port 或 -g:源端口欺骗
–source-port 或其简写 -g 选项允许你在扫描时指定数据包的源端口。这可以用于规避某些基于端口的防火墙规则,或用于某些特定的探测技术。
nmap --source-port <PORT> <target>
–spoof-mac:MAC 地址欺骗
–spoof-mac 选项可以用于伪造数据包的源 MAC 地址。
nmap --spoof-mac <MAC_ADDRESS|vendor|0|PARA> <target>
例:nmap --spoof-mac 00:11:22:33:44:55 192.168.1.1
nmap --spoof-mac apple 192.168.1.1
主机发现PING
windows中可以使用:
for /L %i in (1,1,255) do @ping -w 100 -n 1 192.168.1.%i
-w 100: 指定超时时间为 100 毫秒。
-n 1: 只发送一个 ping 请求。
linux中使用bash脚本
for i in {1..255}
doping -c 1 -W 1 192.168.1.$i &> /dev/nullif [ $? -eq 0 ]; thenecho "192.168.1.$i is up"elseecho "192.168.1.$i is down"fi
done
NC
nc -vz 10.0.0.1 20-80
-v(详细模式)和-z(只扫描端口,不发送任何数据)参数。
使用bash批量扫描:
#!/bin/bash# 定义子网和端口范围
subnet="192.168.1"
start_port=1
end_port=1024for ip in {1..255}; do #扫描192.168.1.1-255,也可以使用subnet(192.168.1.1 192.168.1.2 .......)来批量for port in $(seq $start_port $end_port); do# 使用nc命令扫描端口,-z选项表示只扫描而不发送数据,-w 1表示超时时间为1秒nc -z -w 1 $subnet.$ip $port &> /dev/nullif [ $? -eq 0 ]; thenecho "$subnet.$ip:$port is open"fidone
done
这篇关于主机探测和端口扫描的流量隐藏问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!