激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - python實現簡單tftp(基于udp協議)

python實現簡單tftp(基于udp協議)

2021-03-24 00:19Erick-LONG Python

這篇文章主要為大家詳細介紹了python實現簡單tftp,基于udp協議,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了python實現簡單tftp的具體代碼,供大家參考,具體內容如下

python實現簡單tftp(基于udp協議)

  • tftp是基于udp的協議
  • 實現簡單的tftp,首先要有tftp的協議圖。
  • tftp默認接收端口為69,但每次有連接過來后,tftp會隨機分配一個端口來專門為這個連接來服務。
  • 操作碼:1.上傳 2.下載 3.傳數據 4.接收確認 5.錯誤碼

tftp服務器簡單實現:

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
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)) #第一次用隨機端口發送
 
 while True:
  recv_data,user_info = s_up.recvfrom(1024) #第二次客戶連接我隨機端口
  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)) #第二次我用隨機端口發
   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)) #文件不存在時發送
  exit() #只會退出此線程
 
 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)) #數據第一次發送
  if len(read_data) < 512:
   print('傳輸完成, 對方下載成功')
   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) #第一次客戶連接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('對方想下載數據',filename)
    t = Thread(target = download, args = (filename,user_ip,user_port))
    t.start()  
   elif caozuoma[0] == 2:
    print('對方想上傳數據',filename)
    t = Thread(target = upload, args = (filename,user_ip,user_port))
    t.start()  
 
if __name__ == '__main__':
 main()

上傳數據簡單實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#!/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)) #第一次發給服務器69端口
 
f = open('王輝.jpg','rb')
 
recv_data = s.recvfrom(1024) #第一次接收數據
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)) #第二次發給服務器的隨機端口
 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

下載數據簡單實現:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/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)) #第一次發送, 連接服務器69端口
 
f = open(filename,'ab')
 
while 1:
 recv_data = s.recvfrom(1024) #接收數據
 caozuoma,ack_num = struct.unpack('!HH',recv_data[0][:4]) #獲取數據塊編號
 rand_port = recv_data[1][1] #獲取服務器的隨機端口
 
 if int(caozuoma) == 5:
  print('服務器返回: 文件不存在...')
  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)) #回復ACK確認包

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.cnblogs.com/Erick-L/p/7144139.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: xxxx18韩国护士hd老师 | 国产精品久久久av | 91情侣偷在线精品国产 | 免费视频www在线观看 | 色多多视频导航 | 国产精品1区2区在线观看 | 精品国产一区二区三 | av免费在线播放网址 | 色婷婷一区二区三区 | 久久国产免费 | 精品国产乱码久久久久久丨区2区 | 欧美性生活久久 | 日本一级黄色大片 | www.91sese| 国产一区视频在线免费观看 | 欧美日韩亚洲国产 | 欧美视频在线一区二区三区 | 国产成人高清在线观看 | 成人在线不卡 | 久久国产精品无码网站 | 免费看国产 | 午夜神马福利视频 | 99re3 | 操操操日日日干干干 | 精品小视频 | 亚洲视频在线免费看 | 久久亚洲国产午夜精品理论片 | 色999久久久精品人人澡69 | 国产成人精品一区二区仙踪林 | 欧美第1页 | 国产精品美女一区二区 | 日本中文字幕高清 | 久久国产精品久久久久久久久久 | 九九热播视频 | 国产18成人免费视频 | 又黄又爽免费无遮挡在线观看 | 日韩av一二三区 | 精品1| free台湾极品性hd | 福利在线小视频 | 九九午夜 |