2017-06-21 76 views
0

我試圖從一個不包含websocket的組件發送一個答案給我的websocket-server。我的WebSocket服務器如下所示:React原生Websocket外部訪問

componentDidMount() { 
    var ws = new WebSocket('ws:// URL'); 
    ws.onmessage = this.handleMessage.bind(this); 
    ... 
    } 

如何將「var ws」傳遞給其他類或組件。或者是否有可能使websocket在全球範圍內可訪問? 非常感謝您的幫助!

+0

我覺得首先你應該連接到WebSocket的,一旦連接則僅可以發送。在本地系統中測試它。就像給出路徑爲ws://127.0.0.1:8100 –

+0

您用於導航的內容是相關的 – MattyK14

+0

我正在使用反應導航 – Hang

回答

1

我發現幫助從這個問題在計算器的解決方案:

,請訪問:

React native: Always running component

我創建了這樣一個新的類WebsocketController:

let instance = null; 

    class WebsocketController{ 
     constructor() { 
      if(!instance){ 
       instance = this; 
      } 
      this.ws = new WebSocket('ws://URL'); 
      return instance; 
     } 
    } 

    export default WebsocketController 

然後在我的其他類,我需要我的WebSocket我只是把它叫做是這樣的:

let controller = new WebsocketController(); 
    var ws = controller.ws; 

+0

卡住任何地方你是代碼讓我看得更遠。我找到了這個我用作靈感的鏈接。 https://blog.parsable.com/websocket-connections-and-ui-with-react-nuclearjs-and-immutablejs-7fd341dd050b – ccostel

0

WebSocket連接

保持這種代碼一些文件,將其命名是.js extenstion。例如:websocket.js

var WebSocketServer = require("ws").Server; 

var wss = new WebSocketServer({port:8100}); 

wss.broadcast = function broadcast(msg) { 
    console.log(msg); 
    wss.clients.forEach(function each(client) { 
     client.send(msg); 
    }); 
}; 

wss.on('connection', function connection(ws) { 
    // Store the remote systems IP address as "remoteIp". 
    var remoteIp = ws.upgradeReq.connection.remoteAddress; 
    // Print a log with the IP of the client that connected. 
    console.log('Connection received: ', remoteIp); 

    ws.send('You successfully connected to the websocket.'); 

    ws.on('message',wss.broadcast); 
}); 

在您的應用程序/網站的一面。創建.js文件。例如:client.js

var SERVER_URL = 'ws://127.0.0.1:8100'; 
var ws; 

function connect() { 
    //alert('connect'); 
    ws = new WebSocket(SERVER_URL, []); 
    // Set the function to be called when a message is received. 
    ws.onmessage = handleMessageReceived; 
    // Set the function to be called when we have connected to the server. 
    ws.onopen = handleConnected; 
    // Set the function to be called when an error occurs. 
    ws.onerror = handleError; 

} 

function handleMessageReceived(data) { 
    // Simply call logMessage(), passing the received data. 
    logMessage(data.data); 
} 

function handleConnected(data) { 
    // Create a log message which explains what has happened and includes 
    // the url we have connected too. 
    var logMsg = 'Connected to server: ' + data.target.url; 
    // Add the message to the log. 
    logMessage(logMsg) 

    ws.send("hi am raj"); 
} 

function handleError(err) { 
    // Print the error to the console so we can debug it. 
    console.log("Error: ", err); 
} 

function logMessage(msg) { 
    // $apply() ensures that the elements on the page are updated 
    // with the new message. 
    $scope.$apply(function() { 
     //Append out new message to our message log. The \n means new line. 
     $scope.messageLog = $scope.messageLog + msg + "\n"; 
    }); 

} 

請讓我知道,如果你面對任何問題與此代碼

+0

實際上它不認識到這一點:var WebSocketServer = require(「ws」)。Server ; – Hang

+0

安裝此:npm安裝ws –

+0

我發現了另一種解決方案,看下面我發佈了一個答案 – Hang