问题描述
这是我的脚本,我的问题是为什么 Socket 扫描本地主机而 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
另一个例子: