亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python如何實現ftp文件傳輸功能

發布時間:2021-03-23 09:47:51 來源:億速云 閱讀:526 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關python如何實現ftp文件傳輸功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

本文實例為大家分享了python實現ftp文件傳輸的具體代碼,具體內容如下

主要步驟可以分為以下幾步:

1.讀取文件名
2.檢測文件是否存在
3.打開文件
4.檢測文件大小
5.發送文件大小和 md5值給客戶端
6.等客戶端確認
7.開始邊讀邊發數據

服務器端代碼:

import socket,os,time
import hashlib
 
server =socket.socket()
server.bind(('0.0.0.0',6666))
server.listen()
print("等待....")
while True:
 conn,addr = server.accept()
 print("new conn:",conn)
 while True:
 data = conn.recv(1024)
 if not data:
 print("client is disconnection")
 break
 cmd,filename = data.decode().split() #記錄指令和文件名
 print(filename)
 #判斷當前目錄是否存在該文件,而且必須是文件,而不是目錄
 if os.path.isfile(filename):
 f = open(filename,'rb')
 #m = hashlib.md5() # 創建md5
 file_size = os.stat(filename).st_size #stat() 可以返回文件的大小值
 conn.send((str(file_size)).encode()) # 發送文件大小
 conn.recv(1024) #等待返回信息
 for line in f:
 # m.updata(line) 
 conn.send(line)
 #print("file md5",m.hexdigest()) #打印md5值
 f.close()

客戶端代碼:

# Author: zjt
import socket
 
client = socket.socket()
 
client.connect(("0.0.0.0",6666))
 
 
while True:
 cmd = input(">>>:").strip()
 
 if len(cmd)==0 :continue
 
 if cmd.startswith("get"):
 client.send(cmd.encode())
 server_response = client.recv(1024)
 print("server response: ",server_response)
 client.send(b"ready to recv file")
 
 # 開始接收文件
 file_total_size = int(server_response.decode())
 received_size = 0 # 記錄接收文件的大小
 filename = cmd.split()[1]
 # 因為兩個目錄一致,接收的文件名不能與原文件相同
 f = open(filename+".new","wb")
 while received_size < file_total_size:
 data = client.recv(1024)
 received_size += len(data)
 f.write(data)
 print("total:",file_total_size," present: ",received_size)
 else:
 print("file has received done!")
 f.close()
 
client.close()

用80M的文件傳輸測試,效果如下:

python如何實現ftp文件傳輸功能

程序升級:

前面的代碼還沒添加md5進行驗證,現在對代碼進行升級

服務器端代碼:

import socket,os,time
import hashlib
 
server =socket.socket()
server.bind(('0.0.0.0',8888))
server.listen()
print("等待....")
while True:
 conn,addr = server.accept()
 print("new conn:",conn)
 while True:
 data = conn.recv(1024)
 if not data:
 print("client is disconnection")
 break
 cmd,filename = data.decode().split() #記錄指令和文件名
 print(filename)
 #判斷當前目錄是否存在該文件,而且必須是文件,而不是目錄
 if os.path.isfile(filename):
 f = open(filename,'rb')
 m = hashlib.md5() # 創建md5
 file_size = os.stat(filename).st_size #stat() 可以返回文件的大小值
 conn.send((str(file_size)).encode()) # 發送文件大小
 conn.recv(1024) #等待返回信息
 for line in f:
 m.update(line)
 conn.send(line)
 print("file md5",m.hexdigest()) #打印md5值
 
 f.close()
 conn.send(m.hexdigest().encode()) # 發送md5
 
 print("我真的已經發過去了",m.hexdigest().encode())
 
 print("send done")
 
server.close()

客戶端代碼:

import socket
import hashlib
client = socket.socket()
client.connect(("0.0.0.0",8888))
while True:
 cmd = input(">>>:").strip()
 if len(cmd)==0 :continue
 if cmd.startswith("get"):
 client.send(cmd.encode())
 server_response = client.recv(1024)
 print("server response: ",server_response)
 client.send(b"ready to recv file")
 # 開始接收文件
 file_total_size = int(server_response.decode())
 received_size = 0 # 記錄接收文件的大小
 filename = cmd.split()[1]
 # 因為兩個目錄一致,接收的文件名不能與原文件相同
 f = open(filename+".new","wb")
 m = hashlib.md5()
 while received_size < file_total_size:
 data = client.recv(1024)
 received_size += len(data)
 m.update(data)
 f.write(data)
 #print("total:",file_total_size," present: ",received_size)
 else:
 new_file_md5 = m.hexdigest()
 print("client file md5:",new_file_md5)
 print("file has received done!")
 print("total:",file_total_size," present: ",received_size)
 f.close()
 sever_file_md5 = client.recv(1024)
 print("client file md5:",new_file_md5)
 print("server file md5:",sever_file_md5)
client.close()

兩個程序在linux 環境下運行,結果如下:

python如何實現ftp文件傳輸功能

可以看到傳輸后文件大小變大了一點點,而且md5前后值也不同,說明文件傳輸發生了改變。

現在講程序在windows環境下運行,結果如下:

python如何實現ftp文件傳輸功能

此時可以看到windows上沒有問題,文件大小相同,且md5值也一致。

原因分析:

之所以會發生這種情況,是因為在linux上運行時,最后一次傳輸文件與發送md5值的時候,發生可粘包,導致最后一次接收文件的時候,連同md5的數據一并發送了。而客戶端也當作一條接收信息,全部接收了。所以客戶端出現沒有收到來自服務器端的md5值,多出來的那一點點,就是md5值的大小。

解決方法:

在接收文件的時候,判斷當前剩余多少文件需要接收,如果大于1024,就接收1024大小的文件,否則就只接收剩下全部的文件,防止最后一次接收多余的數據。

只需要對客戶端代碼進行修改,修改后代碼如下:

import socket
import hashlib
client = socket.socket()
client.connect(("0.0.0.0",8888))
while True:
 cmd = input(">>>:").strip()
 if len(cmd)==0 :continue
 if cmd.startswith("get"):
 client.send(cmd.encode())
 server_response = client.recv(1024)
 print("server response: ",server_response)
 client.send(b"ready to recv file")
 # 開始接收文件
 file_total_size = int(server_response.decode())
 received_size = 0 # 記錄接收文件的大小
 filename = cmd.split()[1]
 f = open(filename+".new","wb")
 m = hashlib.md5()
 while received_size < file_total_size:
 #添加一次判斷,使最后一次剩多少就接收多少,避免發生粘包
 if file_total_size - received_size > 1024:
  size = 1024
 else: # 最后一次,剩多少收多少
  size = file_total_size - received_size
 data = client.recv(size)
 received_size += len(data)
 m.update(data)
 f.write(data)
 else:
 new_file_md5 = m.hexdigest() 
 print("client file md5:",new_file_md5)
 print("file has received done!")
 print("total:",file_total_size," present: ",received_size)
 print("下一句關閉文件")
 f.close()
 print("開始接收md5 ") 
 sever_file_md5 = client.recv(1024)
 print("client file md5:",new_file_md5)
 print("server file md5:",sever_file_md5)
client.close()

關于“python如何實現ftp文件傳輸功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

望奎县| 施秉县| 桃园县| 习水县| 平凉市| 陕西省| 新兴县| 修武县| 赤城县| 治多县| 大冶市| 石景山区| 罗山县| 盘锦市| 峨眉山市| 获嘉县| 探索| 桃江县| 北川| 鞍山市| 衡山县| 余庆县| 高雄县| 望江县| 宁德市| 恩平市| 云阳县| 怀仁县| 林甸县| 手机| 峨边| 长宁县| 山东省| 涡阳县| 调兵山市| 蚌埠市| 井陉县| 中西区| 醴陵市| 漳平市| 合作市|