我有一个带有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进行配置。
答案 0 :(得分:0)
订阅的工作原理基于目的地。默认模式为/exchange/routingkey
在您的情况下,/topic/notify
表示您订阅默认交换topic
路由密钥为notify