詳解Python3的TFTP文件傳輸
TFTP文件傳輸
功能:
1、獲取文件列表
2、上傳文件
3、下載文件
4、退出
第一部分,TftpServer部分。
①導入相關模塊
from socket import * import os import signal import sys import time
②確定文件路徑
# 文件庫路徑 FILE_PATH = "/home/tarena/"
③建立一個類,用來實現(xiàn)服務器功能模塊
class TftpServer(object):
def __init__(self, connfd):
self.connfd = connfd
def do_list(self):
# 獲取列表
file_list = os.listdir(FILE_PATH)
# 如果對應的路徑內沒有文件,返回Empty
if not file_list:
self.connfd.send('Empty'.encode())
return
# 路徑存在文件,向客戶端發(fā)送OK
else:
self.connfd.send(b'OK')
time.sleep(0.1)
files = ""
for file in file_list:
# 排除以'.'開頭的隱藏文件
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
# 如果能正常打開,發(fā)送OK
self.connfd.send(b"OK")
time.sleep(0.1)
# 開始發(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")
# 開始上傳文件
def do_put(self, filename):
try:
fd = open(FILE_PATH + filename, 'w')
except:
self.connfd.send("Some error")
# 如果能正常打開文件,則發(fā)送OK
self.connfd.send(b'OK')
# 開始發(fā)送
while True:
# data為文件內容
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()
# 設置端口可重用
sockfd.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
# 綁定地址
sockfd.bind(ADDR)
# 設置監(jiān)聽隊列大小
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)建父子進程
pid = os.fork()
if pid < 0:
print("Process creation failed")
continue
elif pid == 0:
# 子進程負責請求接收和發(fā)送,所以節(jié)省資源,關閉連接套字
sockfd.close()
tftp = TftpServer(connfd)
# 接收客戶端請求
while True:
data = connfd.recv(1024).decode()
if not data:
continue
# 調用do_list方法獲取文件列表
elif data[0] == 'L':
tftp.do_list()
# data ==> G filename
# 文件名以G開頭,以空格為間隔發(fā)送過來
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("客戶端退出")
sys.exit(0)
else:
connfd.close()
continue
⑤運行主控制流程,等待客戶端連接
if __name__ == "__main__": main()
第二部分,TftpClient
①導入相關模塊
from socket import * import sys import time
②實現(xiàn)基本的請求功能
class TftpServer(object):
def __init__(self, sockfd):
self.sockfd = sockfd
def do_list(self):
self.sockfd.send(b"L") # 發(fā)送請求類型
# 等待接收服務器端確認
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:
# 失敗的原因由服務器發(fā)送過來
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對象調用請求方法
while True:
print("=======命令選項========")
print("******* list *********")
print("*******get file ******")
print("*******put file ******")
print("******* quit *********")
print("======================")
cmd = input("請輸入命令>>")
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
④運行客戶端
if __name__ == "__main__": main()
第三部分,展示

一下就不做逐一顯示,如有問題,煩請之處修正,共同進步!
- Python實現(xiàn)基于HTTP文件傳輸實例
- Python實現(xiàn)的簡單文件傳輸服務器和客戶端
- python實現(xiàn)的一個p2p文件傳輸實例
- python使用tcp實現(xiàn)局域網(wǎng)內文件傳輸
- python基于xmlrpc實現(xiàn)二進制文件傳輸?shù)姆椒?/a>
- python cs架構實現(xiàn)簡單文件傳輸
- python 使用poster模塊進行http方式的文件傳輸?shù)椒掌鞯姆椒?/a>
- python3.5基于TCP實現(xiàn)文件傳輸
- Python實現(xiàn)簡單的文件傳輸與MySQL備份的腳本分享
- python實現(xiàn)UDP協(xié)議下的文件傳輸
相關文章
pymongo如何通過oplog獲取數(shù)據(jù)(mongodb)
使用MongoDB的oplog(操作日志)進行數(shù)據(jù)同步是高級的用法,主要用于復制和故障恢復,這篇文章主要介紹了pymongo通過oplog獲取數(shù)據(jù)(mongodb),需要的朋友可以參考下2023-09-09
對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法
今天小編就為大家分享一篇對Django中static(靜態(tài))文件詳解以及{% static %}標簽的使用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
接口自動化多層嵌套json數(shù)據(jù)處理代碼實例
這篇文章主要介紹了接口自動化多層嵌套json數(shù)據(jù)處理代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11
在jupyter notebook中使用pytorch的方法
這篇文章主要介紹了在jupyter notebook中使用pytorch的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09
詳解分布式系統(tǒng)中如何用python實現(xiàn)Paxos
提到分布式算法,就不得不提 Paxos 算法,在過去幾十年里,它基本上是分布式共識的代 名詞,因為當前最常用的一批共識算法都是基于它改進的。比如,F(xiàn)ast Paxos 算法、 Cheap Paxos 算法、Raft 算法、ZAB 協(xié)議等等。2021-05-05

