JavaScript Node.js和Socket.IO广播服务器

4
我只需要一个简单的例子,说明如何做一个Node.JS服务器。
基本上,Node.JS将有两个运行的服务器: - 一个简单的TCP服务器 - 一个Socket.IO服务器
目标是将来自TCP客户端的数据转发给对其感兴趣的各种Socket.IO客户端。
这样做的原因是为了方便与其他语言通信(我将有一个Java服务器通过TCP套接字发送消息,因为我找不到更好的方法来实现这一点 - 所有可用的Java库(socket.io服务器和在Java中实现的客户端)都存在缺陷),因为几乎每种语言都有套接字API。
TCP客户端将在连接后发送一个字符串,Node.JS服务器将创建一个相应的命名空间并为其提供数据,以便Socket.IO客户端能够接收服务器从TCP客户端转发的数据。
步骤:
- 监听TCP连接 - 在新的TCP连接上从客户端接收一个字符串 - 使用由tcp客户端提供的字符串创建一个Socket.IO服务器命名空间 - 开始从TCP客户端接收数据,并将其广播到所有连接到此套接字打开时创建的命名空间的Socket.IO客户端
必须以多个TCP客户端和Socket.IO客户端可以进行通信的方式进行操作。
我找不到一种有效的方法来实现这一点,如果有人能提供一个简单的例子,我相信它会对许多人有所帮助(因为Node.JS和Socket.IO缺乏文档),并且对于已经了解此主题的人来说,这很容易实现。
谢谢。
更新:
我做到了:
node.js代码:
var javaPort = 8080;
var sIOPort = 8081;
var javaServer = require('net').createServer();
var browserServer = require('socket.io').listen(sIOPort);

console.log('Socket.IO version: ' + require('socket.io').version);

javaServer.on('listening', function () {
    console.log('Server is listening on ' + javaPort);
});

javaServer.on('error', function (e) {
    console.log('Server error: ' + e.code);
});

javaServer.on('close', function () {
    console.log('Server closed');
});

javaServer.on('connection', function (javaSocket) {
    var clientAddress = javaSocket.address().address + ':' + javaSocket.address().port;
    console.log('Java ' + clientAddress + ' connected');

    var firstDataListenner = function (data) {
        console.log('Received namespace from java: ' + data);
        javaSocket.removeListener('data', firstDataListenner);
        createNamespace(data, javaSocket);
    }

    javaSocket.on('data', firstDataListenner);

    javaSocket.on('close', function() {
        console.log('Java ' + clientAddress + ' disconnected');
    });
});

javaServer.listen(javaPort);

function createNamespace(namespaceName, javaSocket) {
    var browserConnectionListenner = function (browserSocket) {
        console.log('Browser Connected');
        var javaSocketDataListenner = function(data) {
            console.log('Data received from java socket and sent to browser: ' + data);
            browserSocket.emit('m', data + '\r\n');
        }

        var javaSocketClosedListenner = function() {
            console.log('The java socket that was providing data has been closed, removing namespace'); 
            browserSocket.disconnect();
            browserServer.of('/' + namespaceName).removeListener('connection', browserConnectionListenner);
            javaSocket.removeListener('data', javaSocketDataListenner);
            javaSocket.removeListener('close', javaSocketClosedListenner);
        }

        javaSocket.on('close', javaSocketClosedListenner);
        javaSocket.on('data', javaSocketDataListenner);

        browserSocket.on('disconnect', function () {
            console.log('Browser Disconnected');
            javaSocket.removeListener('data', javaSocketDataListenner);
            javaSocket.removeListener('close', javaSocketClosedListenner);
        });
    }

    var namespace = browserServer.of('/' + namespaceName).on('connection', browserConnectionListenner);
}

Java 代码:

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.Socket;

public class Client {

    public static void main(String[] args) {
        try {
            Socket nodejs = new Socket("localhost", 8080);
            sendMessage(nodejs, "testnamespace");
            Thread.sleep(100);
            int x = 0;
            while (true)
            {
                sendMessage(nodejs, x + "");
                x++;
                Thread.sleep(1000);
                System.out.println(x + " has been sent to server");
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void sendMessage(Socket s, String message) throws IOException {
        s.getOutputStream().write(message.getBytes("UTF-8"));
        s.getOutputStream().flush();
    }

    public static String readMessage(Socket s) throws IOException {
        InputStream is = s.getInputStream();
        int curr = -1;
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        while ((curr = is.read()) != -1) {
            if (curr == '\n') {
                break;
            }
            baos.write(curr);
        }
        return baos.toString("UTF-8");
    }
}

HTML代码:

<html>
    <head>
    <script src="socket.io.js"></script>
    </head>
    <body>
    <script>
        var socket = io.connect("http://localhost/testnamespace", {port: 8081});
        console.log(io.version);
        socket.on('connect', function () {
            console.log('Connected');
            });
        socket.on('m', function (msg) {
            console.log('Message received: ' + msg);
        });
        socket.on('disconnect', function () {
            console.log('Disconnected');
        });
    </script>
    </body>
</html>

工作原理:

Java通过TCP套接字连接到nodejs,然后发送一个名称空间名称,nodejs使用该名称创建一个socket.io服务器,并将java套接字发送的所有消息转发到与该名称空间连接的所有socket.io客户端。

如果有人看到错误或可以改进的地方,请分享。

谢谢。

1个回答

0

我正在制作一个类似的应用程序,但是我使用了基于TCP的ZeroMQ。这段代码非常简单易懂。

在这里查看我的代码: https://github.com/EhevuTov/netPeek

请执行以下操作:

$:node support/msu_gen.js
$:node app.js

希望这有所帮助。

顺便说一下,我认为我的回调函数没有正确实现。我认为我每次传递消息时都设置了事件对象。如果您找到更好的方法,请提交拉取请求以进行修复。:-)


谢谢分享,我发现你使用ZeroMQ的解决方案非常适合我的需求,但是我离截止日期很近,所以我只能采用更简单(并不是最好的)的方法。将来我一定会深入研究类似于你的项目。=) - David Benko

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接