如何解决为什么 Python-Nmap 不能扫描 Localhost 而 Socket 可以?
这是我的脚本,我的问题是为什么 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
另一个例子:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。