我正在尝试在python中以程序方式生成图像以发送到node.js实例,因此我可以通过websocket将这些图像实时传送到浏览器。
我的第一次测试迭代只是在我的node.js服务器中打开一个jpeg文件,将其编码为base64,然后使用socket.io将其发送到浏览器(在端口81上)。每次发送数据时都能正常工作。
然后我尝试在python中打开相同的文件,连接到原始TCP node.js服务器(在端口9090上),并将文件发送到节点服务器,以便它转发到浏览器(在端口81上)。大约一半的时间,数据节点接收似乎被破坏,但每次从文件读取的数据python都很好。
令我惊讶的是节点和浏览器之间的数据通道很好,但python和节点之间的数据通道却没有。是这样的情况,websockets提供了一些原始TCP套接字中不存在的纠错。如果不是,可能导致此错误的原因是什么?
感谢。
JS代码
var io = require('socket.io').listen(81);
var fs = require('fs');
var path = require('path');
var net = require('net');
var mousex = 0;
var mousey = 0;
var imgdata = "";
var oldimgdata = "";
var imagehaschanged = true;
//Serving python
var server = net.createServer(function (stream) {
stream.setEncoding("base64");
stream.on("connect", function () {
console.log("rendering client connected");
});
stream.on("data", function (data) {
//parsed = JSON.parse(data);
imgdata = data;
preview = imgdata.substr(0,50);
console.log(preview);
if (imgdata!=oldimgdata) {
imagehaschanged=true;
}
console.log("rendering client sent data:");
posdata = JSON.stringify({'x':mousex ,'y':mousey});
stream.write(posdata, "ascii", function() {
console.log("Sent response");
});
});
stream.on("end", function () {
stream.end();
console.log("rendering client closed connection");
});
});
server.listen(9090);
//Serving web
io.sockets.on('connection', function (socket) {
socket.emit('ready');
socket.on('position', function(data){
mousex = data.x;
mousey = data.y;
if (imagehaschanged) {
socket.emit('image', {data: imgdata});
oldimgdata = imgdata;
imagehaschanged = false;
}
//fs.readFile("1.jpg", processRead);
//console.log(data.x + ", " + data.y)
});
});
Python代码
import socket, json,# base64
from time import sleep, time
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect(('localhost', 9090))
while 1:
t0 = time()
f = open("1.jpg")
data = f.read()
f.close()
imgdata = data # base64.b64encode(data)
print imgdata[:50]
len = s.send(imgdata)
response = json.loads(s.recv(4096))
print "Response is:", response
sleep(2)
print "Time taken is: ", time()-t0
答案 0 :(得分:2)
无论在tcp套接字的客户端有多少写入,以及你通常无法控制数据块大小的消息大小,你将获得serever的'data'处理程序(tcp只保证它们在订购)。您需要手动构建数据(最简单的方法是使用帧大小作为前缀并缓冲传入的数据)