带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