詳解Python3的TFTP文件傳輸
TFTP文件傳輸
功能:
1、獲取文件列表
2、上傳文件
3、下載文件
4、退出
第一部分,TftpServer部分。
①導(dǎo)入相關(guān)模塊
from socket import * import os import signal import sys import time
②確定文件路徑
# 文件庫(kù)路徑 FILE_PATH = "/home/tarena/"
③建立一個(gè)類(lèi),用來(lái)實(shí)現(xiàn)服務(wù)器功能模塊
class TftpServer(object): def __init__(self, connfd): self.connfd = connfd def do_list(self): # 獲取列表 file_list = os.listdir(FILE_PATH) # 如果對(duì)應(yīng)的路徑內(nèi)沒(méi)有文件,返回Empty if not file_list: self.connfd.send('Empty'.encode()) return # 路徑存在文件,向客戶(hù)端發(fā)送OK else: self.connfd.send(b'OK') time.sleep(0.1) files = "" for file in file_list: # 排除以'.'開(kāi)頭的隱藏文件 if file[0] != '.' and \ os.path.isfile(FILE_PATH + file): files = files + file + '#' # 返回文件列表 self.connfd.send(files.encode()) # 下載文件功能 def do_get(self, filename): try: fd = open(FILE_PATH + filename, 'rb') except: self.connfd.send("File doesn't exist".encode()) return # 如果能正常打開(kāi),發(fā)送OK self.connfd.send(b"OK") time.sleep(0.1) # 開(kāi)始發(fā)送文件 try: for line in fd: self.connfd.send(line) fd.close() except Exception as e: print(e) time.sleep(0.1) self.connfd.send(b'##') print("File send over") # 開(kāi)始上傳文件 def do_put(self, filename): try: fd = open(FILE_PATH + filename, 'w') except: self.connfd.send("Some error") # 如果能正常打開(kāi)文件,則發(fā)送OK self.connfd.send(b'OK') # 開(kāi)始發(fā)送 while True: # data為文件內(nèi)容 data = self.connfd.recv(1024).decode() if data == "##": break fd.write(data) fd.close() print("上傳完畢")
④主流程控制
def main(): # 創(chuàng)建套接字/地址/端口 HOST = '0.0.0.0' PORT = 8888 ADDR = (HOST, PORT) sockfd = socket() # 設(shè)置端口可重用 sockfd.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1) # 綁定地址 sockfd.bind(ADDR) # 設(shè)置監(jiān)聽(tīng)隊(duì)列大小 sockfd.listen(5) signal.signal(signal.SIGCHLD, signal.SIG_IGN) print("Listen to port 8888....") while True: try: connfd, addr = sockfd.accept() except KeyboardInterrupt: sockfd.close() sys.exit("Server exit") except Exception as e: print(e) continue print("Client login:", addr) # 創(chuàng)建父子進(jìn)程 pid = os.fork() if pid < 0: print("Process creation failed") continue elif pid == 0: # 子進(jìn)程負(fù)責(zé)請(qǐng)求接收和發(fā)送,所以節(jié)省資源,關(guān)閉連接套字 sockfd.close() tftp = TftpServer(connfd) # 接收客戶(hù)端請(qǐng)求 while True: data = connfd.recv(1024).decode() if not data: continue # 調(diào)用do_list方法獲取文件列表 elif data[0] == 'L': tftp.do_list() # data ==> G filename # 文件名以G開(kāi)頭,以空格為間隔發(fā)送過(guò)來(lái) elif data[0] == 'G': filename = data.split(' ')[-1] tftp.do_get(filename) elif data[0] == 'P': filename = data.split(' ')[-1] tftp.do_put(filename) elif data[0] == 'Q': print("客戶(hù)端退出") sys.exit(0) else: connfd.close() continue
⑤運(yùn)行主控制流程,等待客戶(hù)端連接
if __name__ == "__main__": main()
第二部分,TftpClient
①導(dǎo)入相關(guān)模塊
from socket import * import sys import time
②實(shí)現(xiàn)基本的請(qǐng)求功能
class TftpServer(object): def __init__(self, sockfd): self.sockfd = sockfd def do_list(self): self.sockfd.send(b"L") # 發(fā)送請(qǐng)求類(lèi)型 # 等待接收服務(wù)器端確認(rèn) data = self.sockfd.recv(1024).decode() if data == 'OK': data = self.sockfd.recv(4096).decode() files = data.split('#') for file in files: print(file) print("%%%%%There is file list%%%%%\n") else: # 失敗的原因由服務(wù)器發(fā)送過(guò)來(lái) print(data) def do_get(self, filename): self.sockfd.send(('G '+filename).encode()) data = self.sockfd.recv(1024).decode() if data == 'OK': fd = open(filename, 'w') while True: data = self.sockfd.recv(1024).decode() if data == "##": break fd.write(data) fd.close() print("%s Download over\n" % filename) else: print(data) def do_put(self, filename): try: fd = open(filename, 'rb') except: print("There is no such file") return self.sockfd.send(("P " + filename).encode()) data = self.sockfd.recv(1024).decode() if data == 'OK': for line in fd: self.sockfd.send(line) fd.close() time.sleep(0.1) self.sockfd.send(b'##') print("%s upload over" % filename) else: print(data) def do_quit(self): self.sockfd.send(b'Q')
③主流程控制
# 套接字連接 def main(): if len(sys.argv) < 3: print("argv is error") return HOST = sys.argv[1] PORT = int(sys.argv[2]) ADDR = (HOST, PORT) sockfd = socket() sockfd.connect(ADDR) tftp = TftpServer(sockfd) # tftp對(duì)象調(diào)用請(qǐng)求方法 while True: print("=======命令選項(xiàng)========") print("******* list *********") print("*******get file ******") print("*******put file ******") print("******* quit *********") print("======================") cmd = input("請(qǐng)輸入命令>>") if cmd.strip() == 'list': tftp.do_list() elif cmd[:3] == "get": filename = cmd.split(' ')[-1] tftp.do_get(filename) elif cmd[:3] == "put": filename = cmd.split(' ')[-1] tftp.do_put(filename) elif cmd.strip() == "quit": tftp.do_quit() sockfd.close() sys.exit("Welcome") else: print("Enter the right order!!!") continue
④運(yùn)行客戶(hù)端
if __name__ == "__main__": main()
第三部分,展示
一下就不做逐一顯示,如有問(wèn)題,煩請(qǐng)之處修正,共同進(jìn)步!
- Python實(shí)現(xiàn)基于HTTP文件傳輸實(shí)例
- Python實(shí)現(xiàn)的簡(jiǎn)單文件傳輸服務(wù)器和客戶(hù)端
- python實(shí)現(xiàn)的一個(gè)p2p文件傳輸實(shí)例
- python使用tcp實(shí)現(xiàn)局域網(wǎng)內(nèi)文件傳輸
- python基于xmlrpc實(shí)現(xiàn)二進(jìn)制文件傳輸?shù)姆椒?/a>
- python cs架構(gòu)實(shí)現(xiàn)簡(jiǎn)單文件傳輸
- python 使用poster模塊進(jìn)行http方式的文件傳輸?shù)椒?wù)器的方法
- python3.5基于TCP實(shí)現(xiàn)文件傳輸
- Python實(shí)現(xiàn)簡(jiǎn)單的文件傳輸與MySQL備份的腳本分享
- python實(shí)現(xiàn)UDP協(xié)議下的文件傳輸
相關(guān)文章
基于Python實(shí)現(xiàn)對(duì)PDF文件的OCR識(shí)別
大家可能聽(tīng)說(shuō)過(guò)使用Python進(jìn)行OCR識(shí)別操作。在Python中,最出名的庫(kù)便是Google所資助的tesseract。利用tesseract可以很輕松地對(duì)圖像進(jìn)行識(shí)別。現(xiàn)在問(wèn)題來(lái)了,如果想對(duì)一個(gè)PDF文檔進(jìn)行OCR識(shí)別,該怎么做呢?下面一起來(lái)看看。2016-08-08pymongo如何通過(guò)oplog獲取數(shù)據(jù)(mongodb)
使用MongoDB的oplog(操作日志)進(jìn)行數(shù)據(jù)同步是高級(jí)的用法,主要用于復(fù)制和故障恢復(fù),這篇文章主要介紹了pymongo通過(guò)oplog獲取數(shù)據(jù)(mongodb),需要的朋友可以參考下2023-09-09對(duì)Django中static(靜態(tài))文件詳解以及{% static %}標(biāo)簽的使用方法
今天小編就為大家分享一篇對(duì)Django中static(靜態(tài))文件詳解以及{% static %}標(biāo)簽的使用方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-07-07接口自動(dòng)化多層嵌套json數(shù)據(jù)處理代碼實(shí)例
這篇文章主要介紹了接口自動(dòng)化多層嵌套json數(shù)據(jù)處理代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11Python使用Turtle模塊繪制國(guó)旗的方法示例
這篇文章主要給大家介紹了關(guān)于Python使用Turtle模塊繪制國(guó)旗的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02在jupyter notebook中使用pytorch的方法
這篇文章主要介紹了在jupyter notebook中使用pytorch的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09詳解分布式系統(tǒng)中如何用python實(shí)現(xiàn)Paxos
提到分布式算法,就不得不提 Paxos 算法,在過(guò)去幾十年里,它基本上是分布式共識(shí)的代 名詞,因?yàn)楫?dāng)前最常用的一批共識(shí)算法都是基于它改進(jìn)的。比如,F(xiàn)ast Paxos 算法、 Cheap Paxos 算法、Raft 算法、ZAB 協(xié)議等等。2021-05-05pytorch使用 to 進(jìn)行類(lèi)型轉(zhuǎn)換方式
今天小編就為大家分享一篇pytorch使用 to 進(jìn)行類(lèi)型轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-01-01