python實(shí)現(xiàn)ping命令小程序
ping的原理是發(fā)送一個ICMP請求包,然后根據(jù)目的地址的應(yīng)答包來判斷是否能夠和這個主機(jī)進(jìn)行通信。
我們使用python實(shí)現(xiàn),借助于scapy來進(jìn)行編寫程序。
from scapy.all import *
import time,struct,random
# 編寫ping一個包的函數(shù)。
def ping_one(dst = '36.152.44.95',ttl_no = 64,id_no = 345,seq_no = 5):
start_time = time.time()
# 將時間轉(zhuǎn)換為二進(jìn)制序列。
time_to_bytes = struct.pack('>d',start_time)
# 進(jìn)行發(fā)送ICMP包,發(fā)送出去一個,收回來一個。
ping_one_result = sr1(IP(dst = dst,ttl = ttl_no)/ICMP(seq = seq_no,id = id_no)/time_to_bytes, timeout = 1, verbose=False)
# print(ping_one_result.show())
# 判斷收回來的包是不是ICMP的應(yīng)答包,和序列號是否相同。
try:
if ping_one_result.getlayer('ICMP').type == 0 and ping_one_result.getlayer('ICMP').seq == seq_no:
# print('進(jìn)行解析包')
# 提取IP頭部中的源IP地址,也就是我們ping的IP地址。
reply_src_IP = ping_one_result.getlayer('IP').src
# 提取序列號。
reply_icmp_seq = ping_one_result.getlayer('ICMP').seq
# 提取ttl
reply_icmp_ttl = ping_one_result.getlayer('IP').ttl
# 數(shù)據(jù)長度等于 數(shù)據(jù)長度(Raw) + 墊片長度(Padding) + 8字節(jié)(ICMP頭部長度)
if ping_one_result.getlayer(Raw) != None:
Raw_length = len(ping_one_result.getlayer(Raw).load)
else:
Raw_length = 0
if ping_one_result.getlayer(Padding) != None:
Padding_length = len(ping_one_result.getlayer(Padding).load)
else:
Padding_length = 0
# 計算數(shù)據(jù)長度。
reply_data_length = Raw_length + Padding_length + 8
# 取出數(shù)據(jù)部分,這里的數(shù)據(jù)部分是我們發(fā)送ICMP請求包的時候填入的時間。
reply_data = ping_one_result.getlayer(Raw).load
# 定義我們收包的時間。
end_time = time.time()
# 將數(shù)據(jù)時間部分進(jìn)行轉(zhuǎn)換。
reply_data_time = struct.unpack('>d',reply_data)
# 然后打印出轉(zhuǎn)換后的類型。
# print(type(reply_data_time))
# print(reply_data_time)
time_to_pass_ms = (end_time - reply_data_time[0]) * 1000
# (接收時間 - 發(fā)送時間) * 1000為毫秒數(shù)為消耗時間的毫秒數(shù)
# print(time_to_pass_ms)
return reply_data_length,reply_src_IP,reply_icmp_seq,reply_icmp_ttl,time_to_pass_ms
except Exception as e:
# 打印出錯誤。
# print('e', e)
# 匹配錯誤是否為NoneType類型。
if re.match('.*NoneType.*', str(e)):
print('錯誤了')
# 如果沒有回應(yīng),就返回None
return None
def ping(dst = '36.152.44.95'):
# 這里其實(shí)可以取進(jìn)程號的,但是我們用隨機(jī)生成一個數(shù)字模擬一下。
id_no = random.randint(0,65535)
# print(id_no)
# 然后進(jìn)行發(fā)送5個數(shù)據(jù)包。
for i in range(1,6):
# 調(diào)用ping一個包函數(shù),入?yún)槟康男枰猵ing的IP地址。ttl,id,和序列號。seq。
ping_result = ping_one(dst,64,id_no,i)
if ping_result != None:
print('%d bytes from %s: icmp_seq=%d ttl=%d time=%4.2f ms' % (ping_result[0], ping_result[1], ping_result[2], ping_result[3], ping_result[4]))
else:
print('.',end = '',flush = True)
# 這里我們暫停一秒。
time.sleep(1)
if __name__ == "__main__":
ping('36.152.44.95')
但現(xiàn)在為止,我們的ping小程序就用python實(shí)現(xiàn)了,接下來就可以用wireshark工具抓包來看一下,進(jìn)行ping百度的地址。

以上就是python實(shí)現(xiàn)ping命令小程序的詳細(xì)內(nèi)容,更多關(guān)于python ping命令的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python實(shí)現(xiàn)在字符串中查找子字符串的方法
這篇文章主要介紹了python實(shí)現(xiàn)在字符串中查找子字符串的方法,涉及Python中find方法的相關(guān)使用技巧,需要的朋友可以參考下2015-07-07
Python使用窮舉法求兩個數(shù)的最大公約數(shù)問題
這篇文章主要介紹了Python使用窮舉法求兩個數(shù)的最大公約數(shù)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12
人工智能學(xué)習(xí)Pytorch梯度下降優(yōu)化示例詳解
這篇文章主要為大家介紹了人工智能學(xué)習(xí)Pytorch梯度下降優(yōu)化示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-11-11
python多進(jìn)程并發(fā)demo實(shí)例解析
這篇文章主要介紹了python多進(jìn)程并發(fā)demo實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-12-12
Python 新建文件夾與復(fù)制文件夾內(nèi)所有內(nèi)容的方法
今天小編就為大家分享一篇Python 新建文件夾與復(fù)制文件夾內(nèi)所有內(nèi)容的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10

