3

当我使用此命令扫描 IP 地址时

# nmap -sP 192.168.0.120/25

当我有地址和子网时,你能帮我获取 IP 范围吗?因为我试图理解这一点,但直到现在还没有结果..提前谢谢

4

1 回答 1

4

您命令中的网络采用CIDR表示法。第一部分(在 之前/)定义哪个网络,第二部分定义设置了多少位网络掩码。IPv4 地址是 4 个字节或 32 位信息。/25表示该地址的 25 位用于表示网络,32 - 25 = 7剩下的位用于寻址网络上的主机。一个/25网络可以容纳2^7 = 128主机,而不是网络和广播地址。要获取网络地址(地址块的开头),您需要获取给定的地址并按位 - 并将其与2^32 - 2^7. 在这种情况下(使用 Python):

>>> # Get the integer value of the address
>>> import struct
>>> ip = struct.unpack(">I", struct.pack("4B", 192, 168, 0, 120))[0]
>>> bin(ip)
'0b11000000101010000000000001111000'
>>> # Bitwise-and with the netmask
>>> net = ip & (2**32 - 2**7)
>>> bin(net)
'0b11000000101010000000000000000000'
>>> # Convert back to dotted-decimal
>>> struct.unpack("4B", struct.pack(">I", net))
(192, 168, 0, 0)

所以网络地址是192.168.0.0,你有 128 个地址,所以你的目标范围是 192.168.0.0 - 192.168.0.127。

于 2013-11-11T21:04:58.570 回答