我之前用过socket跨语言跨平台通信,不过那时传的字节都比较小,等我想传输图片时问题出现了,传输时报错,网上查了查,是传输数据过大导致的,于是客户端获取对应文件的size,并把它分段传输,服务端拿到分段的数据并把它重新合并成你想要的文件
废话不多说,直接放代码
客户端:
# -*- coding: UTF-8 -*-
import socket, os, struct
import time
import cv2
"""set ip address"""
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('192.168.200.243', 50005))
pre_name = os.path.dirname(os.path.realpath(__file__))
while True:
filepath = pre_name+'/0.jpg'
image = cv2.imread(filepath)
gray = cv2.cvtColor( image, cv2.COLOR_BGR2GRAY )
if os.path.isfile(filepath):
fileinfo_size = struct.calcsize('128sl') # 定义打包规则
# 定义文件头信息,包含文件名和文件大小
fhead = struct.pack('128sl', bytes(os.path.basename(filepath).encode('utf-8')),os.stat(filepath).st_size)
print(fhead)
s.send(fhead)
print('client filepath: ', os.path.basename(filepath), os.stat(filepath).st_size)
fo = open(filepath, 'rb')
while True:
filedata = fo.read(1024)
if not filedata:
break
s.send(filedata)
#time.sleep(0.5)
fo.close()
print('send over...')
#time.sleep(0.5)
# s.close()
客户端向服务端传图片,你也可以接入自己的摄像头,把传输的图片动态化,我这里只是循环传输一张图片作演示
服务端:
import socket, time, struct, os, threading
host = '0.0.0.0'
port = 50005
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 定义socket类型
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1) # 即时释放
s.bind((host, port)) # 绑定需要监听的Ip和端口号,tuple格式
s.listen(5)
def conn_thread(connection, address):
location = ''
i = 0
while True:
try:
connection.settimeout(600)
fileinfo_size = struct.calcsize('128sl')
buf = connection.recv(fileinfo_size)
#print(buf)
if buf: # 如果不加这个if,第一个文件传输完成后会自动走到下一句
filename, filesize = struct.unpack('128sl', buf)
print("照片大小:"+str(filesize))
if filesize< 0 or filesize > 2432075:
# da = connection.recv()
continue
filename = filename.decode().strip('\00')
# print(filename)
#filename = os.path.join('e:\\', ('new_' + filename))
print('file new name is %s, filesize is %s' % (filename, filesize))
# 获取当前时间
localtime &#