欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Python3的TFTP文件傳輸

 更新時(shí)間:2018年06月26日 08:46:49   作者:Le-Bill  
本篇內(nèi)容給大家詳細(xì)講述了Python3的TFTP文件傳輸?shù)南嚓P(guān)知識(shí)點(diǎn),有需要的朋友可以參考下。

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)步!

相關(guān)文章

  • 基于Python實(shí)現(xiàn)對(duì)PDF文件的OCR識(shí)別

    基于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-08
  • 使用keras2.0 將Merge層改為函數(shù)式

    使用keras2.0 將Merge層改為函數(shù)式

    這篇文章主要介紹了使用keras2.0 將Merge層改為函數(shù)式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-05-05
  • pymongo如何通過(guò)oplog獲取數(shù)據(jù)(mongodb)

    pymongo如何通過(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)簽的使用方法

    今天小編就為大家分享一篇對(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í)例

    這篇文章主要介紹了接口自動(dòng)化多層嵌套json數(shù)據(jù)處理代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Python使用Turtle模塊繪制國(guó)旗的方法示例

    Python使用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
  • 使用Python發(fā)送HTML格式郵件的步驟詳解

    使用Python發(fā)送HTML格式郵件的步驟詳解

    在現(xiàn)代通信中,電子郵件是一種常見(jiàn)的溝通方式,通過(guò)Python編程語(yǔ)言,您可以使用內(nèi)置的庫(kù)來(lái)發(fā)送郵件,并在郵件中嵌入HTML內(nèi)容和圖片,本文將介紹如何使用Python發(fā)送帶有HTML格式內(nèi)容,以及涉及的步驟和代碼示例
    2023-08-08
  • 在jupyter notebook中使用pytorch的方法

    在jupyter notebook中使用pytorch的方法

    這篇文章主要介紹了在jupyter notebook中使用pytorch的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • 詳解分布式系統(tǒng)中如何用python實(shí)現(xiàn)Paxos

    詳解分布式系統(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-05
  • pytorch使用 to 進(jìn)行類(lèi)型轉(zhuǎn)換方式

    pytorch使用 to 進(jìn)行類(lèi)型轉(zhuǎn)換方式

    今天小編就為大家分享一篇pytorch使用 to 進(jìn)行類(lèi)型轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01

最新評(píng)論