0

我想使用用 react 和 webpack 构建的浏览器应用程序连接到 GDAX websocket api。我不能使用官方的 gdax-node 或 gdax-toolkit api,因为它们与 webpack 不兼容。我决定尝试使用 socket.io 自己连接到 websocket,但下面的代码从未建立连接。在下面的代码中,连接后我的“订阅”日志消息永远不会出现。如何让此代码连接或至少显示错误消息?

const io = require('socket.io-client');

var subscribe = {
  "type": "subscribe",
  "channels": [{"name": "ticker", "product_ids": ["BTC-EUR"]}]
};

function subscribeToTimer(cb) {
  console.log('Opening socket');
  var socket = io.connect('wss://ws-feed.gdax.com');

  socket.on('connection', function(socket) {
    console.log('Subscribing');

    socket.on('disconnect', function(socket) {
      console.log('Clinet disconnected.');
    });    
  });

  //socket.on('message', timestamp => cb(null, timestamp));
  socket.on('message', data => { console.log(data); });
  socket.on('error', data => { console.log(data); });
}
export { subscribeToTimer };
4

2 回答 2

0

由于 gdax 仅将wssurl 暴露给 public 而 socket.io 不支持wssws连接,我们必须找到解决方法。这global.websocket足以在浏览器中建立连接。或者您也可以查看这个。它只是简单地包装了ws包,当你通过 webpack 构建以供浏览器使用时,它将用browser.js.

于 2018-03-02T20:19:37.900 回答
0

Socket.io 不是用于此目的的适当库。我将它切换为使用 global 的 websocket,它工作正常。

function subscribeToTimer(cb) {
  console.log('Opening socket');
  const socket = new WebSocket('wss://ws-feed.gdax.com');

  socket.addEventListener('message', function(event) {
    console.log('new message', event.data);
  });

  socket.addEventListener('open', function(event) {
    console.log('Subscribing');


    var subscribe = '{"type": "subscribe", "channels": [{"name": "ticker", "product_ids": ["BTC-EUR"]}]}';
    socket.send(subscribe);

    socket.addEventListener('close', function(event) {
      console.log('Client disconnected.');
    });    
  });

  //socket.addEventListener('message', timestamp => cb(null, timestamp));
}
于 2018-03-02T19:24:47.297 回答