python socket报错
传输小文件没有问题,大文件(500M)报错:socket.error: [Errno 10053]
服务端:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
'''
等待连接
等待发送文件
读取数据
写入文件并且保存
等待连接
'''
import socket
import threading
import time
import struct
def function(newsock, address):
FILEINFO_SIZE = struct.calcsize('128sI')
'''定义文件信息(包含文件名和文件大小)大小。128s代表128个char[](文件名),I代表一个integer or long(文件大小)'''
while 1:
try:
fhead = newsock.recv(FILEINFO_SIZE)
filename, filesize = struct.unpack('128sI', fhead)
'''把接收到的数据库进行解包,按照打包规则128sI'''
print "address is: ", address
print filename, len(filename), type(filename)
print filesize
#filename = 'new_'+filename.strip('\00') # 命名新文件new_传送的文件
filename = filename.strip('\00')
fp = open(filename, 'wb') # 新建文件,并且准备写入
restsize = filesize
print "recving..."
while 1:
if restsize > 1024: # 如果剩余数据包大于1024,就去1024的数据包
filedata = newsock.recv(1024)
else:
filedata = newsock.recv(restsize)
fp.write(filedata)
break
if not filedata:
break
fp.write(filedata)
restsize = testsize - len(filedata) # 计算剩余数据包大小
if restsize <= 0:
break
fp.close()
print "recv succeeded !!File named:", filename
except:
print "the socket partner maybe closed"
newsock.close()
break
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 创建tcp连接
sock.bind(('127.0.0.1', 8887)) # 定于端口和ip
sock.listen(5) # 监听
while True:
newsock, address = sock.accept()
print "accept another connection"
tmpThread = threading.Thread(target=function, args=(newsock, address)) # 如果接收到文件,创建线程
tmpThread.start() # 执行线程
print 'end'
客户端:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding("utf-8")
'''
输入文件名,并且上传
'''
import socket
import time
import struct
import os
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.settimeout(500)
e = 0
try:
sock.connect(('127.0.0.1', 8887))
print 'connect...'
except socket.timeout, e:
print 'timeout', e
except socket.error, e:
print 'error', e
except e:
print 'any', e
if not e:
while (1):
filename = raw_input('input your filename------->') # 输入文件名
FILEINFO_SIZE = struct.calcsize('128sI') # 编码格式大小
fhead = struct.pack('128sI', filename, os.stat(filename).st_size) # 按照规则进行打包
sock.send(fhead) # 发送文件基本信息数据
fp = open(filename, 'rb')
while 1: # 发送文件
filedata = fp.read(1024)
if not filedata:
break
sock.send(filedata)
print "sending over..."
fp.close()
相关阅读:
NSArray转plist失败
听说百度云平台Baidu App Engine开始内测了?求证求来源
隐藏元素如何获取相关数值?
ngnix rewrite打开页面出现404
一般网站的验证码校验是怎么做的?
linux shell 命令 df -ahP 这个P是什么意思?
RN自制搜索界面中的点击函数只能运行一次。
帮忙看一个linux下通配符转译的问题
数据相似的实体传入adapter,如何做到使用同个adapter
为毛fastjson字段为null时不输出空字符串?
angular能通过其他办法兼容到ie7吗
js 代码 ;这段代码看不懂,求详细一点的解释;
代码更适合“程序员”阅读,会不会不适合“计算机”执行?
为什么在 javascript 中 [1, 2] + [3, 4] 返回的是 "1,23,4"
StrutsTestCase遭遇missing configuration resources
react中是否有什么比较好用的移动端手势的库呢?希望各位能推荐下
as添加依赖时一直是gradle:download状态
结构体的输出
函数怎样调用自己会形成一个莫比乌斯带
webapp在ios上将数字转变成了链接显示,怎么解决?