为什么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

另一个例子: