首页 文章

如何构建使用node.js通过TCP发送消息的消息?

提问于
浏览
5

我需要从node.js TCP服务器向许多TCP客户端发送JSON字符串 .

为了从客户端的套接字/流中读取消息,我需要进行某种消息框架 . 一种方法是将消息的长度作为数组添加消息的长度 - 然后将其转换为客户端消息的缓冲区大小 .

我如何在服务器上的node.js / javascript中执行此类操作,然后使用.NET客户端在客户端读取它?

鉴于此客户端代码,如何使用javascript / node在服务器端正确构建消息?

TcpClient client = new TcpClient(server, port);
        var netStream = client.GetStream();

        // read the length of the message from the first 4 bytes
        byte[] b = new byte[4];
        netStream.Read(b, 0, b.Length);
        int messageLength = BitConverter.ToInt32(b, 0);

        // knowing the length, read the rest of the message
        byte[] buffer = new byte[messageLength];
        netStream.Read(buffer, b.Length, buffer.Length);
        var message = System.Text.Encoding.UTF8.GetString(buffer);

1 回答

  • 3

    要取消对nodejs中的传入数据的取消框架,您可以尝试使用node-bufferlistnode-buffers或手动创建自己的FSM并将其与传入的数据块一起提供

    服务器端更简单:

    function sendPacket(stream, buffer)
    {
        var prefix = new Buffer(4);
        var length = buffer.length;
        var offset = 0;
        // serialize 32bit little endian unsigned int
        prefix[offset++] = length & 0xff;
        prefix[offset++] = (length >> 8)  & 0xff );
        prefix[offset++] = (length >> 16)  & 0xff );
        prefix[offset++] = (length >> 24)  & 0xff );
        stream.write(prefix);
        stream.write(buffer);
    }
    

    或者您可以使用节点v0.5 buffer.writeUInt32

相关问题