格式化消息以从python客户端发送到socket.io node.js服务器

时间:2022-11-13 09:53:10

I'm trying to get a Python client talking to a Node.js server using Socket.io 0.7, by sending a custom event to the server.

我正在尝试通过向服务器发送自定义事件,使用Socket.io 0.7让Python客户端与Node.js服务器通信。

Based on the Socket.io reference I have found on GitHub, and the following WebSocket Python library.

基于我在GitHub上找到的Socket.io引用,以及下面的WebSocket Python库。

Here's is my code so far:

到目前为止,这是我的代码:

Node server

节点服务器

io.sockets.on('connection', function (socket) {
  socket.on('newimg', function(data) {
        console.log(data);
  });
});

Python client

Python客户端

def handshake(host, port):
    u = urlopen("http://%s:%d/socket.io/1/" % (host, port))
    if u.getcode() == 200:
        response = u.readline()
        (sid, hbtimeout, ctimeout, supported) = response.split(":")
        supportedlist = supported.split(",")
        if "websocket" in supportedlist:
            return (sid, hbtimeout, ctimeout)
        else:
            raise TransportException()
    else:
        raise InvalidResponseException()


try:
    (sid, hbtimeout, ctimeout) = handshake(HOSTNAME, PORT) #handshaking according to socket.io spec.
Except Exception as e:
    print e
    sys.exit(1)
ws = websocket.create_connection("ws://%s:%d/socket.io/1/websocket/%s" % (HOSTNAME, PORT, sid))
print ws.recv()
ws.send("2::")
ws.send("5:1::{'name':'newimg', 'args':'bla'}")
print ws.recv()
print "Closing connection"
ws.close()

Node console output

节点控制台输出

debug - client authorized
info  - handshake authorized 12738935571241622933
debug - setting request GET /socket.io/1/websocket/12738935571241622933
debug - set heartbeat interval for client 12738935571241622933
debug - client authorized for 
debug - websocket writing 1::
debug - websocket received data packet 2::
debug - got heartbeat packet
debug - websocket received data packet 5:1::{'name':'newimg', 'args':'bla'}
debug - acknowledging packet automatically
debug - websocket writing 6:::1
info  - transport end
debug - set close timeout for client 12738935571241622933
debug - cleared close timeout for client 12738935571241622933
debug - cleared heartbeat interval for client 12738935571241622933
debug - discarding transport 

Python console output

Python控制台输出

Done
1::
6:::1
Closing connection

Now it seems the socket event is not being triggered, despite the server responding with ACK. So the message is being correctly received but I am assuming, not formatted properly for socket.io to trigger an event.

现在看来套接字事件没有被触发,尽管服务器用ACK响应。所以消息正在被正确接收,但我假设,没有正确格式化socket.io来触发事件。

I didn't think framing was necessary, however Archie1986 seems to disagree on his response to this: Socket.IO Client Library in Python

我不认为框架是必要的,但Archie1986似乎不同意他对此的回应:Python中的Socket.IO客户端库

What might I be doing wrong here?

我可能在这里做错了什么?

2 个解决方案

#1


20  

I wrapped rod's research into a barebones socket.io client library.

我把rod的研究包装成了一个准确的socket.io客户端库。

pip install -U socketIO-client
python
    from socketIO_client import SocketIO
    with SocketIO('localhost', 8000) as socketIO:
        socketIO.emit('aaa')
        socketIO.wait(seconds=1)

#2


14  

Resolved. I needed to use double quotes. Single quotes are not valid JSON. Woops.

解决。我需要使用双引号。单引号不是有效的JSON。 Woops。

ws.send("5:1::{'name':'newimg', 'args':'bla'}")

Becomes:

变为:

ws.send('5:1::{"name":"newimg", "args":"bla"}')

#1


20  

I wrapped rod's research into a barebones socket.io client library.

我把rod的研究包装成了一个准确的socket.io客户端库。

pip install -U socketIO-client
python
    from socketIO_client import SocketIO
    with SocketIO('localhost', 8000) as socketIO:
        socketIO.emit('aaa')
        socketIO.wait(seconds=1)

#2


14  

Resolved. I needed to use double quotes. Single quotes are not valid JSON. Woops.

解决。我需要使用双引号。单引号不是有效的JSON。 Woops。

ws.send("5:1::{'name':'newimg', 'args':'bla'}")

Becomes:

变为:

ws.send('5:1::{"name":"newimg", "args":"bla"}')