利用Python腳本寫端口掃描器socket,python-nmap
前言:
一個用python寫的簡單的端口掃描器,python環(huán)境為 3.7.0,windows系統(tǒng)
Socket模塊編寫
掃描給定主機是否開放了指定的端口
TCP連接掃描是利用TCP的三次握手來確定主機的端口是否開放。確定主機端口開放之后,給端口發(fā)送消息,接收端口返回的消息,然后判斷該端口運行的服務。
使用時,-H 參數(shù)可以提供主機的域名或者ip地址,-p/-P 寫要掃描的端口,多個端口用逗號分隔
# -*- coding: utf-8 -*-
import optparse
from socket import *
import threading
threadLock=threading.Lock() #實例化threadLock對象
def connScan(Host,Port):
try:
conn=socket(AF_INET,SOCK_STREAM)
conn.connect((Host,Port))
conn.send('test message'.encode("utf-8")) #發(fā)送測試信息給端口
results=conn.recv(100) #接收主機返回的信息
threadLock.acquire() #加鎖
print('[+]%d/tcp open'% Port)
print('[+] '+results.decode("utf-8"))
conn.close()
except Exception as e:
threadLock.acquire()
print(e)
print('[-]%d/tcp closed'% Port)
finally:
threadLock.release() #釋放鎖
conn.close()
def portScan(Host,Ports):
try:
IP=gethostbyname(Host) ##獲得對應主機的ip地址
except:
print("[-] Cannot resolve '%s':Unknown host" %Host)
return
try:
Name=gethostbyaddr(Host) ##獲得ip對應主機的信息
print ("\n[+] Scan Results for:"+Name[0])
except:
print ("\n[+] Scan Results for:"+IP)
setdefaulttimeout(1)
for Port in Ports:
print ("Scanning port "+Port)
connScan(Host,int(Port))
def main():
usage="usage %prog -H <target host> -p/-P <target ports>"
parser=optparse.OptionParser(usage) #創(chuàng)建對象實例
parser.add_option('-H',dest='Host',type='string',help='target host') ##需要的命令行參數(shù)
parser.add_option('-P','-p',dest='Ports',type='string',help='target ports')
(options,args)=parser.parse_args()
Host=options.Host
Ports=str(options.Ports).split(',')
if (Host==None)|(Ports==None): ##如果主機和端口都是空的話
print(parser.usage)
exit(0)
portScan(Host,Ports)
if __name__=='__main__':
main()
python-nmap模塊編寫
我們還可以通過調(diào)用nmap進行端口掃描。
掃描給定ip或給定網(wǎng)段內(nèi)指定端口是否開放
-H 參數(shù)可以掃描一個ip地址也可以掃描一個網(wǎng)段,-p 只能指定一個端口
# -*- coding: utf-8 -*-
import nmap
import optparse
def Test(Hosts,port):
nm=nmap.PortScanner()
nm.scan(Hosts,port)
port_int=int(port) #將端口從字符串轉(zhuǎn)化為int類型的
for t in nm.all_hosts():
if nm[t].has_tcp(port_int): #如果445端口提供了TCP協(xié)議
state=nm[t]['tcp'][port_int]['state'] #判斷該TCP 445 端口的狀態(tài)
if state=='open':
print ('[+]Found Target Host:'+t)
return
def main():
usage="usage %prog -H <target host> -p/-P <target port>"
parser=optparse.OptionParser(usage) #創(chuàng)建對象實例
parser.add_option('-H',dest='Host',type='string',help='target host') ##需要的命令行參數(shù)
parser.add_option('-P','-p',dest='Port',type='string',help='target ports')
(options,args)=parser.parse_args()
Hosts=options.Host
Port=options.Port
if (Hosts==None)|(Port==None): #如果主機和端口都是空的話
print(parser.usage)
exit(0) #退出
else:
Test(Hosts,Port)
if __name__=='__main__':
main()
到此這篇關(guān)于利用Python腳本寫端口掃描器socket,python-nmap的文章就介紹到這了,更多相關(guān)Python socket,python-nmap內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python數(shù)據(jù)分析matplotlib設置多個子圖的間距方法
今天小編就為大家分享一篇Python數(shù)據(jù)分析matplotlib設置多個子圖的間距方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Python多線程編程(八):使用Event實現(xiàn)線程間通信
這篇文章主要介紹了Python多線程編程(八):使用Event實現(xiàn)線程間通信,,需要的朋友可以參考下2015-04-04
Python第三方庫qrcode或MyQr生成博客地址二維碼
使用第三方庫qrcode或者MyQr給自己的博客網(wǎng)址快速生成二維碼,一鍵分享,文中含有詳細示例代碼,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10
人工智能——K-Means聚類算法及Python實現(xiàn)
這篇文章主要介紹了人工智能——K-Means聚類算法及Python實現(xiàn),一個能夠找到我圈出的這?些點集的算法,就被稱為聚類算法,下面就來看看文章具體的介紹吧2022-01-01
Python中的枚舉函數(shù)enumerate()的具體用法
本文主要介紹了Python中的枚舉函數(shù)enumerate()的具體用法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-06-06
使用Python開發(fā)游戲運行腳本成功調(diào)用大漠插件
閑來無事,想通過python來實現(xiàn)一些簡單的游戲輔助腳本,而游戲輔助腳本的主要原理就是通過程序來查找游戲程序窗口,模擬實現(xiàn)鼠標點擊和鍵盤按鍵等事件來實現(xiàn)游戲輔助的,對Python開發(fā)游戲運行腳本相關(guān)知識感興趣的朋友跟隨小編一起看看吧2021-11-11
python遍歷迭代器自動鏈式處理數(shù)據(jù)的實例代碼
迭代器也是用來遍歷對象成員的,下面這篇文章主要給大家介紹了關(guān)于python遍歷迭代器自動鏈式處理數(shù)據(jù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2022-01-01

