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

python實現(xiàn)簡單tftp(基于udp協(xié)議)

 更新時間:2018年07月30日 14:26:17   作者:Erick-LONG  
這篇文章主要為大家詳細介紹了python實現(xiàn)簡單tftp,基于udp協(xié)議,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

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

tftp服務器簡單實現(xiàn):

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)) #第一次用隨機端口發(fā)送

 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)) #第二次我用隨機端口發(fā)
   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)) #文件不存在時發(fā)送
  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)) #數(shù)據(jù)第一次發(fā)送
  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('對方想下載數(shù)據(jù)',filename)
    t = Thread(target = download, args = (filename,user_ip,user_port)) 
    t.start()   
   elif caozuoma[0] == 2:
    print('對方想上傳數(shù)據(jù)',filename)
    t = Thread(target = upload, args = (filename,user_ip,user_port)) 
    t.start()   

if __name__ == '__main__':
 main()

上傳數(shù)據(jù)簡單實現(xiàn):

#!/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)) #第一次發(fā)給服務器69端口

f = open('王輝.jpg','rb')

recv_data = s.recvfrom(1024) #第一次接收數(shù)據(jù)
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)) #第二次發(fā)給服務器的隨機端口
 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

下載數(shù)據(jù)簡單實現(xiàn):

#!/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)) #第一次發(fā)送, 連接服務器69端口

f = open(filename,'ab')

while 1:
 recv_data = s.recvfrom(1024) #接收數(shù)據(jù)
 caozuoma,ack_num = struct.unpack('!HH',recv_data[0][:4]) #獲取數(shù)據(jù)塊編號
 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確認包

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • python神經(jīng)網(wǎng)絡Pytorch中Tensorboard函數(shù)使用

    python神經(jīng)網(wǎng)絡Pytorch中Tensorboard函數(shù)使用

    這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡Pytorch中Tensorboard常用函數(shù)的使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Python學習之.iloc與.loc的區(qū)別、聯(lián)系和用法

    Python學習之.iloc與.loc的區(qū)別、聯(lián)系和用法

    loc和iloc都是pandas工具中定位某一行的函數(shù),下面這篇文章主要給大家介紹了關于Python學習之.iloc與.loc的區(qū)別、聯(lián)系和用法的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-05-05
  • Pandas DataFrame數(shù)據(jù)存儲格式比較分析

    Pandas DataFrame數(shù)據(jù)存儲格式比較分析

    Pandas 支持多種存儲格式,在本文中將對不同類型存儲格式下的Pandas Dataframe的讀取速度、寫入速度和大小的進行測試對比,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2023-09-09
  • Django項目中使用JWT的實現(xiàn)代碼

    Django項目中使用JWT的實現(xiàn)代碼

    這篇文章主要介紹了Django項目中使用JWT的實現(xiàn)代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • python中k-means和k-means++原理及實現(xiàn)

    python中k-means和k-means++原理及實現(xiàn)

    本文主要介紹了python中k-means和k-means++原理及實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • 詳解python?Warning警告有哪些情況

    詳解python?Warning警告有哪些情況

    這篇文章主要為大家介紹分析了python?Warning警告有哪些情況示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • 詳解python 破解網(wǎng)站反爬蟲的兩種簡單方法

    詳解python 破解網(wǎng)站反爬蟲的兩種簡單方法

    這篇文章主要介紹了詳解python 破解網(wǎng)站反爬蟲的兩種簡單方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • Python 使用 environs 庫定義環(huán)境變量的方法

    Python 使用 environs 庫定義環(huán)境變量的方法

    這篇文章主要介紹了Python 使用 environs 庫來更好地定義環(huán)境變量,本節(jié)我們以 Python 項目為例,說說環(huán)境變量的設置。通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • Python+Tkinter制作在線個性簽名工具

    Python+Tkinter制作在線個性簽名工具

    這篇文章主要為大家分享如何利用Python中的Tkinter庫制作一個簡易的在線個性簽名生成工具,文中的示例代碼講解詳細,感興趣的小伙伴可以了解一下
    2022-03-03
  • python腳本實現(xiàn)查找webshell的方法

    python腳本實現(xiàn)查找webshell的方法

    這篇文章主要介紹了python腳本實現(xiàn)查找webshell的方法,是很實用的一個功能,需要的朋友可以參考下
    2014-07-07

最新評論