Python Socket传输文件示例
发布时间 - 2026-01-10 22:33:47 点击率:次发送端可以不停的发送新文件,接收端可以不停的接收新文件。

例如:发送端输入:e:\visio.rar,接收端会默认保存为 e:\new_visio.rar,支持多并发,具体实现如下;
接收端:
方法一:
#-*- coding: UTF-8 -*-
import socket,time,SocketServer,struct,os,thread
host='192.168.50.74'
port=12307
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #定义socket类型
s.bind((host,port)) #绑定需要监听的Ip和端口号,tuple格式
s.listen(1)
def conn_thread(connection,address):
while True:
try:
connection.settimeout(600)
fileinfo_size=struct.calcsize('128sl')
buf = connection.recv(fileinfo_size)
if buf: #如果不加这个if,第一个文件传输完成后会自动走到下一句
filename,filesize =struct.unpack('128sl',buf)
filename_f = filename.strip('\00')
filenewname = os.path.join('e:\\',('new_'+ filename_f))
print 'file new name is %s, filesize is %s' %(filenewname,filesize)
recvd_size = 0 #定义接收了的文件大小
file = open(filenewname,'wb')
print 'stat receiving...'
while not recvd_size == filesize:
if filesize - recvd_size > 1024:
rdata = connection.recv(1024)
recvd_size += len(rdata)
else:
rdata = connection.recv(filesize - recvd_size)
recvd_size = filesize
file.write(rdata)
file.close()
print 'receive done'
#connection.close()
except socket.timeout:
connection.close()
while True:
connection,address=s.accept()
print('Connected by ',address)
#thread = threading.Thread(target=conn_thread,args=(connection,address)) #使用threading也可以
#thread.start()
thread.start_new_thread(conn_thread,(connection,address))
s.close()
方法二:
#-*- coding: UTF-8 -*-
import socket,time,SocketServer,struct,os
host='192.168.50.74'
port=12307
ADDR=(host,port)
class MyRequestHandler(SocketServer.BaseRequestHandler):
def handle(self):
print('connected from:', self.client_address)
while True:
fileinfo_size=struct.calcsize('128sl') #定义文件信息。128s表示文件名为128bytes长,l表示一个int或log文件类型,在此为文件大小
self.buf = self.request.recv(fileinfo_size)
if self.buf: #如果不加这个if,第一个文件传输完成后会自动走到下一句
self.filename,self.filesize =struct.unpack('128sl',self.buf) #根据128sl解包文件信息,与client端的打包规则相同
print 'filesize is: ',self.filesize,'filename size is: ',len(self.filename) #文件名长度为128,大于文件名实际长度
self.filenewname = os.path.join('e:\\',('new_'+ self.filename).strip('\00')) #使用strip()删除打包时附加的多余空字符
print self.filenewname,type(self.filenewname)
recvd_size = 0 #定义接收了的文件大小
file = open(self.filenewname,'wb')
print 'stat receiving...'
while not recvd_size == self.filesize:
if self.filesize - recvd_size > 1024:
rdata = self.request.recv(1024)
recvd_size += len(rdata)
else:
rdata = self.request.recv(self.filesize - recvd_size)
recvd_size = self.filesize
file.write(rdata)
file.close()
print 'receive done'
#self.request.close()
tcpServ = SocketServer.ThreadingTCPServer(ADDR, MyRequestHandler)
print('waiting for connection...' )
tcpServ.serve_forever()
发送端:
#-*- coding: UTF-8 -*-
import socket,os,struct
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(('192.168.50.74',12307))
while True:
filepath = raw_input('Please Enter chars:\r\n')
if os.path.isfile(filepath):
fileinfo_size=struct.calcsize('128sl') #定义打包规则
#定义文件头信息,包含文件名和文件大小
fhead = struct.pack('128sl',os.path.basename(filepath),os.stat(filepath).st_size)
s.send(fhead)
print 'client filepath: ',filepath
# with open(filepath,'rb') as fo: 这样发送文件有问题,发送完成后还会发一些东西过去
fo = open(filepath,'rb')
while True:
filedata = fo.read(1024)
if not filedata:
break
s.send(filedata)
fo.close()
print 'send over...'
#s.close()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Gemini手机端怎么发图片_Gemini手机端发图方法【步骤】
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】
Bootstrap整体框架之JavaScript插件架构
js实现点击每个li节点,都弹出其文本值及修改
如何在万网自助建站中设置域名及备案?
瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口
Laravel Octane如何提升性能_使用Laravel Octane加速你的应用
WEB开发之注册页面验证码倒计时代码的实现
Laravel怎么清理缓存_Laravel optimize clear命令详解
零服务器AI建站解决方案:快速部署与云端平台低成本实践
图册素材网站设计制作软件,图册的导出方式有几种?
深圳网站制作平台,深圳市做网站好的公司有哪些?
高端建站如何打造兼具美学与转化的品牌官网?
Laravel如何创建自定义Artisan命令?(代码示例)
如何在VPS电脑上快速搭建网站?
宙斯浏览器怎么屏蔽图片浏览 节省手机流量使用设置方法
,怎么在广州志愿者网站注册?
如何基于云服务器快速搭建网站及云盘系统?
如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】
如何在景安云服务器上绑定域名并配置虚拟主机?
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
如何在建站之星绑定自定义域名?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
独立制作一个网站多少钱,建立网站需要花多少钱?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
西安专业网站制作公司有哪些,陕西省建行官方网站?
昵图网官网入口 昵图网素材平台官方入口
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
Laravel如何使用Eloquent进行子查询
iOS正则表达式验证手机号、邮箱、身份证号等
如何在搬瓦工VPS快速搭建网站?
javascript基于原型链的继承及call和apply函数用法分析
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
Android自定义listview布局实现上拉加载下拉刷新功能
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
如何在万网ECS上快速搭建专属网站?
Laravel如何处理表单验证?(Requests代码示例)
Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】
在线制作视频网站免费,都有哪些好的动漫网站?
QQ浏览器网页版登录入口 个人中心在线进入
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
如何用y主机助手快速搭建网站?
Firefox Developer Edition开发者版本入口
智能起名网站制作软件有哪些,制作logo的软件?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集

