使用SockJS(NodeJS) + STOMP客户端的Websockets服务器

3

我有一个使用sockjs sockets的node应用程序。

一些HTML/JS客户端使用stomp 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个回答

1

订阅基于目标工作。默认模式是/exchange/routingkey

在您的情况下,它是/topic/notify,这意味着您订阅默认交换机topic路由键将是notify


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