为什么Python-Nmap 不能扫描Localhost 但Socket 可以?
Why Python-Nmap cannot scan Localhost but Socket can do it?
这是我的脚本,我的问题是为什么 Socket 扫描 Localhost 而 Nmap 不能?
import nmap
import optparse
import socket
tgtHost = "127.0.0.1"
tgtPort = 80
nmScan = nmap.PortScanner()
try:
result = nmScan.scan(tgtHost, str(tgtPort))
nmScan.scan(tgtHost, tgtPort)
state=nmScan[tgtHost]['tcp'][int(tgtPort)]['state']
print(" [*] " + tgtHost + " tcp/"+tgtPort +" "+state)
except:
print(f"{tgtHost} is unreachable.")
try:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.settimeout(0.5)
s.connect((tgtHost, tgtPort))
print(f"Port {tgtPort} is open on {tgtHost}.")
except:
print(f"{tgtHost} is unreachable.")
这是结果。
可能您正在使用 nmap 进行 ping 扫描,但 ping 已关闭。
使用等效于 -Pn
开关(或 -P0
)。
此外,检查 s.connect()
的结果是否实际上是一个有效连接。
使用此方法检查端口是打开还是关闭:
import nmap
tgtHost = "127.0.0.1"
tgtPort = 80
nmScan = nmap.PortScanner()
try:
result = nmScan.scan(tgtHost, str(tgtPort))
state = result['scan'][tgtHost]['tcp'][tgtPort]['state']
print(f"[*] {tgtHost} tcp/{tgtPort} {state}")
except:
print(f"{tgtHost} is unreachable.")
输出:
[*] 127.0.0.1 tcp/80 closed
另一个例子:
这是我的脚本,我的问题是为什么 Socket 扫描 Localhost 而 Nmap 不能?
import nmap
import optparse
import socket
tgtHost = "127.0.0.1"
tgtPort = 80
nmScan = nmap.PortScanner()
try:
result = nmScan.scan(tgtHost, str(tgtPort))
nmScan.scan(tgtHost, tgtPort)
state=nmScan[tgtHost]['tcp'][int(tgtPort)]['state']
print(" [*] " + tgtHost + " tcp/"+tgtPort +" "+state)
except:
print(f"{tgtHost} is unreachable.")
try:
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.settimeout(0.5)
s.connect((tgtHost, tgtPort))
print(f"Port {tgtPort} is open on {tgtHost}.")
except:
print(f"{tgtHost} is unreachable.")
这是结果。
可能您正在使用 nmap 进行 ping 扫描,但 ping 已关闭。
使用等效于 -Pn
开关(或 -P0
)。
此外,检查 s.connect()
的结果是否实际上是一个有效连接。
使用此方法检查端口是打开还是关闭:
import nmap
tgtHost = "127.0.0.1"
tgtPort = 80
nmScan = nmap.PortScanner()
try:
result = nmScan.scan(tgtHost, str(tgtPort))
state = result['scan'][tgtHost]['tcp'][tgtPort]['state']
print(f"[*] {tgtHost} tcp/{tgtPort} {state}")
except:
print(f"{tgtHost} is unreachable.")
输出:
[*] 127.0.0.1 tcp/80 closed
另一个例子: