10.3 網(wǎng)絡(luò)嗅探器和端口掃描器設(shè)計(jì)

10.3.1 網(wǎng)絡(luò)嗅探器

????? 網(wǎng)絡(luò)嗅探器可以檢測(cè)本機(jī)所在局域網(wǎng)內(nèi)的網(wǎng)絡(luò)流量和數(shù)據(jù)包收發(fā)情況。

import socket
import threading
import time

activeDegree = dict()
flag = 1
def main():
    global activeDegree
    global flag
    # 獲取 IP 地址
    HOST = socket.gethostbyname(socket.gethostname())
    print('HOST:', HOST)
    #
    s = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket.IPPROTO_IP)
    s.bind((HOST, 0))   # 0 表示所有端口
    #
    s.setsockopt(socket.IPPROTO_IP, socket.IP_HDRINCL, 1)
    #   打開混雜模式,接收所有包
    s.ioctl(socket.SIO_RCVALL, socket.RCVALL_ON)
    #
    while flag:
        c = s.recvfrom(65565)   # 接收一個(gè)數(shù)據(jù)包
        print(type(c))
        host = c[1][0]
        activeDegree[host] = activeDegree.get(host, 0) + 1
        print(c)
    s.ioctl(socket.SIO_RCVALL, socket.RCVALL_OFF)   # 關(guān)閉混雜模式
    s.close()

t = threading.Thread(target = main)  # 創(chuàng)建線程
t.start()   # 啟動(dòng)線程,開始嗅探
time.sleep(60)
flag = 0
t.join()    # 等待子線程
for item in activeDegree.items():
    print(item)

10.3.2 多進(jìn)程端口掃描器

import socket
import multiprocessing
import sys

def ports(ports_service):
    # 獲取常用端口對(duì)應(yīng)的服務(wù)名稱
    for port in list(range(1, 100)) + [143, 145, 133, 443, 445, 3389, 8080]:
        try:
            ports_service[port] = socket.getservbyport(port)
        except socket.error:
            pass

def ports_scan(host, ports_service):
    ports_open = []
    try:
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        # 超時(shí)時(shí)間的不同會(huì)影響掃描結(jié)果的精確度
        sock.settimeout(0.01)
    except socket.error:
        print('socket creaation error')
        sys.exit()
    for port in ports_service:
        try:
            # 嘗試連接指定端口
            sock.connect((host, port))
            # 記錄打開端口
            ports_open.append(port)
            sock.close()
        except socket.error:
            pass
    return ports_open

if __name__ == '__main__':
    m = multiprocessing.Manager()
    ports_service = dict()
    results = dict()
    ports(ports_service)
    # 創(chuàng)建線程池,允許 8 個(gè)線程同時(shí)運(yùn)行
    pool = multiprocessing.Pool(processes = 8)
    net = '169.254.143.'
    for host_number in map(str, range(200, 256)):
        host = net + host_number
        # 創(chuàng)建一個(gè)新進(jìn)程,同時(shí)記錄運(yùn)行結(jié)果
        results[host] = pool.apply_async(ports_scan, (host, ports_service))
        print('starting ' + host + '...')
    # 關(guān)閉進(jìn)程池,close() 必須在 join() 之前調(diào)用
    pool.close()
    # 等待進(jìn)程池的進(jìn)程全部執(zhí)行結(jié)束
    pool.join()
 
    # 打印輸出結(jié)果
    for host in results:
        print('=' * 30)
        print(host, '.'*10)
        for port in results[host].get():
            print(port, ':', ports_service[port])

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容