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

问题描述:

我有一个带有sockjs套接字的节点应用程序。带SockJS(NodeJS)+ STOMP客户端的Websockets服务器

一些HTML/JS客户端使用了袜子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]; 
    }); 
}); 

客户端使用STOMP协议在sockJS客户端。

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

我不明白订阅如何工作,以及如何在服务器端配置sockjs。

订阅基于目的地进行。默认模式是/exchange/routingkey

在你的情况下,它是/topic/notify这意味着你的订阅默认的Exchange topic routingkey将notify