带有SockJS(NodeJS)+ STOMP客户端的Websockets服务器

时间:2015-11-03 18:37:06

标签: node.js websocket stomp sockjs

我有一个带有sockjs套接字的节点应用程序。

有些HTML / JS客户端使用stock over sock JS,但我不明白订阅是如何工作的:

$scope.initSockets = function() {
    $scope.socket.client = new SockJS('http://localhost:8080/websockets'); => WORKS

    $scope.socket.stomp = Stomp.over($scope.socket.client);
    $scope.socket.stomp.connect({}, function() {
        $scope.socket.stomp.subscribe("/topic", $scope.notify); => NOTIFY Is never called
    });
    $scope.socket.client.onclose = $scope.reconnect;
};

客户端已连接,事件已记录,但$ scope.notify从未被调用。我们如何配置主题订阅?

编辑:

请注意我很清楚。

我正在使用sockjs模块作为websocket服务器。

配置不多:

echo.installHandlers(server, {prefix:'/websockets'});

 // on new connection event
echo.on('connection', function(conn) {

    console.log('New client connected : ' + conn.id);

    // add this client to clients object
    clients[conn.id] = conn;

    // on connection close event
    conn.on('close', function() {
        console.log('Client disconnected ' + conn.id);
        delete clients[conn.id];
    });
});

客户端在sockJS客户端上使用stomp协议。

他们接收消息(关于客户端日志),但它们与“主题”无关,并且未被解析。

我不明白订阅的工作原理以及如何在服务器端使用sockjs进行配置。

1 个答案:

答案 0 :(得分:0)

订阅的工作原理基于目的地。默认模式为/exchange/routingkey

在您的情况下,/topic/notify表示您订阅默认交换topic路由密钥为notify