python實(shí)現(xiàn)簡(jiǎn)單tftp(基于udp協(xié)議)
本文實(shí)例為大家分享了python實(shí)現(xiàn)簡(jiǎn)單tftp的具體代碼,供大家參考,具體內(nèi)容如下
- tftp是基于udp的協(xié)議
- 實(shí)現(xiàn)簡(jiǎn)單的tftp,首先要有tftp的協(xié)議圖。
- tftp默認(rèn)接收端口為69,但每次有連接過(guò)來(lái)后,tftp會(huì)隨機(jī)分配一個(gè)端口來(lái)專(zhuān)門(mén)為這個(gè)連接來(lái)服務(wù)。
- 操作碼:1.上傳 2.下載 3.傳數(shù)據(jù) 4.接收確認(rèn) 5.錯(cuò)誤碼
tftp服務(wù)器簡(jiǎn)單實(shí)現(xiàn):
from threading import Thread from socket import * import struct def upload(filename,user_ip,user_port): num = 0 f = open(filename,'ab') s_up = socket(AF_INET,SOCK_DGRAM) send_data_1 = struct.pack("!HH",4,num) s_up.sendto(send_data_1,(user_ip,user_port)) #第一次用隨機(jī)端口發(fā)送 while True: recv_data,user_info = s_up.recvfrom(1024) #第二次客戶(hù)連接我隨機(jī)端口 caozuohao_up,ack_num = struct.unpack('!HH',recv_data[:4]) print(caozuohao_up,ack_num,num) if int(caozuohao_up) == 3 and ack_num == num : f.write(recv_data[4:]) send_data = struct.pack("!HH",4,num) s_up.sendto(send_data,(user_ip,user_port)) #第二次我用隨機(jī)端口發(fā) num = num + 1 if len(recv_data) < 516: print(user_ip+'上傳文件'+filename+':完成') f.close() exit() def download(filename,user_ip,user_port): s_down = socket(AF_INET, SOCK_DGRAM) num = 0 try: f = open(filename,'rb') except: error_data = struct.pack('!HHHb',5,5,5,num) s_down.sendto(error_data, (user_ip,user_port)) #文件不存在時(shí)發(fā)送 exit() #只會(huì)退出此線(xiàn)程 while True: read_data = f.read(512) send_data = struct.pack('!HH',3,num) + read_data s_down.sendto(send_data, (user_ip,user_port)) #數(shù)據(jù)第一次發(fā)送 if len(read_data) < 512: print('傳輸完成, 對(duì)方下載成功') exit() recv_ack = s_down.recv(1024) #第二次接收 caozuoma,ack_num = struct.unpack("!HH", recv_ack) # print(caozuoma,ack_num,len(read_data)) num += 1 if int(caozuoma) != 4 or int(ack_num) != num-1 : exit() f.close() s = socket(AF_INET,SOCK_DGRAM) s.bind(('',69)) def main(): while 1: recv_data,(user_ip,user_port) = s.recvfrom(1024) #第一次客戶(hù)連接69端口 print(recv_data, user_ip, user_port) if struct.unpack('!b5sb',recv_data[-7:]) == (0, b'octet', 0): caozuoma = struct.unpack('!H',recv_data[:2]) filename = recv_data[2:-7].decode('gb2312') if caozuoma[0] == 1: print('對(duì)方想下載數(shù)據(jù)',filename) t = Thread(target = download, args = (filename,user_ip,user_port)) t.start() elif caozuoma[0] == 2: print('對(duì)方想上傳數(shù)據(jù)',filename) t = Thread(target = upload, args = (filename,user_ip,user_port)) t.start() if __name__ == '__main__': main()
上傳數(shù)據(jù)簡(jiǎn)單實(shí)現(xiàn):
#!/usr/bin/env python3 #coding=utf-8 import struct from socket import * server_ip = '192.168.119.157' send_data_1 = struct.pack('!H8sb5sb',2,'王輝.jpg'.encode('gb2312'),0,b'octet',0) s = socket(AF_INET,SOCK_DGRAM) s.sendto(send_data_1,(server_ip,69)) #第一次發(fā)給服務(wù)器69端口 f = open('王輝.jpg','rb') recv_data = s.recvfrom(1024) #第一次接收數(shù)據(jù) rand_port = recv_data[1][1] print() ack_num = struct.unpack("!HH",recv_data[0][:4]) num = 0 while True: read_data = f.read(512) send_data = struct.pack('!HH',3,num) + read_data s.sendto(send_data,(server_ip,rand_port)) #第二次發(fā)給服務(wù)器的隨機(jī)端口 recv_data_2,userinfo = s.recvfrom(1024) print(recv_data_2) ack_num = struct.unpack('!H',recv_data_2[2:4]) print(len(read_data),num,ack_num[0],rand_port) if len(read_data) < 512 or ack_num[0] != num : break num = num + 1
下載數(shù)據(jù)簡(jiǎn)單實(shí)現(xiàn):
#!/usr/bin/env python3 #coding=utf-8 import struct from socket import * filename = 'test.jpg' server_ip = '192.168.1.113' send_data = struct.pack('!H%dsb5sb'%len(filename),1,filename.encode('gb2312'),0,'octet'.encode('gb2312'),0) s = socket(AF_INET,SOCK_DGRAM) s.sendto(send_data,(server_ip,69)) #第一次發(fā)送, 連接服務(wù)器69端口 f = open(filename,'ab') while 1: recv_data = s.recvfrom(1024) #接收數(shù)據(jù) caozuoma,ack_num = struct.unpack('!HH',recv_data[0][:4]) #獲取數(shù)據(jù)塊編號(hào) rand_port = recv_data[1][1] #獲取服務(wù)器的隨機(jī)端口 if int(caozuoma) == 5: print('服務(wù)器返回: 文件不存在...') break print(caozuoma,ack_num,rand_port,len(recv_data[0])) f.write(recv_data[0][4:]) if len(recv_data[0]) < 516: break ack_data = struct.pack("!HH",4,ack_num) s.sendto(ack_data,(server_ip,rand_port)) #回復(fù)ACK確認(rèn)包
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python實(shí)現(xiàn)UDP協(xié)議下的文件傳輸
- python網(wǎng)絡(luò)編程 使用UDP、TCP協(xié)議收發(fā)信息詳解
- python UDP(udp)協(xié)議發(fā)送和接收的實(shí)例
- 使用python編寫(xiě)udp協(xié)議的ping程序方法
- Python實(shí)現(xiàn)基于TCP UDP協(xié)議的IPv4 IPv6模式客戶(hù)端和服務(wù)端功能示例
- Python網(wǎng)絡(luò)編程之TCP與UDP協(xié)議套接字用法示例
- Python+Socket實(shí)現(xiàn)基于UDP協(xié)議的局域網(wǎng)廣播功能示例
- python3實(shí)現(xiàn)UDP協(xié)議的服務(wù)器和客戶(hù)端
- python實(shí)現(xiàn)的udp協(xié)議Server和Client代碼實(shí)例
- python 基于UDP協(xié)議套接字通信的實(shí)現(xiàn)
相關(guān)文章
python神經(jīng)網(wǎng)絡(luò)Pytorch中Tensorboard函數(shù)使用
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)Pytorch中Tensorboard常用函數(shù)的使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05Python學(xué)習(xí)之.iloc與.loc的區(qū)別、聯(lián)系和用法
loc和iloc都是pandas工具中定位某一行的函數(shù),下面這篇文章主要給大家介紹了關(guān)于Python學(xué)習(xí)之.iloc與.loc的區(qū)別、聯(lián)系和用法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-05-05Pandas DataFrame數(shù)據(jù)存儲(chǔ)格式比較分析
Pandas 支持多種存儲(chǔ)格式,在本文中將對(duì)不同類(lèi)型存儲(chǔ)格式下的Pandas Dataframe的讀取速度、寫(xiě)入速度和大小的進(jìn)行測(cè)試對(duì)比,有需要的朋友可以借鑒參考下,希望能夠有所幫助2023-09-09Django項(xiàng)目中使用JWT的實(shí)現(xiàn)代碼
這篇文章主要介紹了Django項(xiàng)目中使用JWT的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11python中k-means和k-means++原理及實(shí)現(xiàn)
本文主要介紹了python中k-means和k-means++原理及實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05詳解python 破解網(wǎng)站反爬蟲(chóng)的兩種簡(jiǎn)單方法
這篇文章主要介紹了詳解python 破解網(wǎng)站反爬蟲(chóng)的兩種簡(jiǎn)單方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Python 使用 environs 庫(kù)定義環(huán)境變量的方法
這篇文章主要介紹了Python 使用 environs 庫(kù)來(lái)更好地定義環(huán)境變量,本節(jié)我們以 Python 項(xiàng)目為例,說(shuō)說(shuō)環(huán)境變量的設(shè)置。通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02Python+Tkinter制作在線(xiàn)個(gè)性簽名工具
這篇文章主要為大家分享如何利用Python中的Tkinter庫(kù)制作一個(gè)簡(jiǎn)易的在線(xiàn)個(gè)性簽名生成工具,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-03-03python腳本實(shí)現(xiàn)查找webshell的方法
這篇文章主要介紹了python腳本實(shí)現(xiàn)查找webshell的方法,是很實(shí)用的一個(gè)功能,需要的朋友可以參考下2014-07-07