שאלה כללית ב WebSocket
-
בשביל שהשרת יכול ליזום תקשורת יש להחזיק סוקט פתוח.
כלומר הלקוח יוזם פתיחת תקשורת, ואז היא נשארת פתוחה. והלקוח מאזין לקבלת מידע מהשרת.
כעת יש שתי נושאים למימוש, צד הלקוח וצד השרת.
צד הלקוח זה API של HTML5, והוא פשוט יחסית, ראה פה: https://www.html5rocks.com/en/tutorials/websockets/basics/צד השרת בnodejs תתקין חבילה, כמו ws, ואז אתה מקים שרת ממש בקלות:
const wss = new WebSocket.Server({ port: 8080 }); wss.on('connection', function connection(ws) { ws.on('message', function incoming(message) { console.log('received: %s', message); }); ws.send('something'); });
כדי ליזום שליחת מידע ללקוחות המחוברים עליך לשמור אותם ברשימה, הנה דוגמא:
const wss = new WebSocket.Server({ port: 8080 }); var clients = []; wss.on('connection', c => clients.push(_ws) ).on('close', c => clients.splice(clients.indexOf(c), 1)); function sendMessageToClient(msg){ clients.forEach(x => x.send(msg)); }
-
@dovid אמר בשאלה כללית ב WebSocket:
wss.on('connection', c => clients.push(_ws)
דוד
מה זה _wswss.on('connection', c => clients.push(_ws)
@אהרן אמר בשאלה כללית ב WebSocket:
@dovid אמר בשאלה כללית ב WebSocket:
wss.on('connection', c => clients.push(_ws)
דוד
מה זה _wswss.on('connection', c => clients.push(_ws)
טעות, צריך לשנות לc.
-
https://stackoverflow.com/a/6756431
כאן יש אפשרות לעשות emit, ואז לחכות להאזין לתשובה שחוזרת.Server var io = require('socket.io').listen(80); io.sockets.on('connection', function (socket) { socket.on("getSomeData", function (name, fn) { fn({ data: "some random data" }); }); }); Client < script src = "http://localhost/socket.io/socket.io.js" ></script > <script> var socket = io.connect('http://localhost'); socket.emit("getSomeData", function(data) { console.log(data); }); </script>
זה בגדול מה שחיפשתי. שימו לב שהקליינט שולח בקשה "getSomeDate", ומקבל את ה data שהוא רוצה.
פשוט וקל. -
https://stackoverflow.com/a/6756431
כאן יש אפשרות לעשות emit, ואז לחכות להאזין לתשובה שחוזרת.Server var io = require('socket.io').listen(80); io.sockets.on('connection', function (socket) { socket.on("getSomeData", function (name, fn) { fn({ data: "some random data" }); }); }); Client < script src = "http://localhost/socket.io/socket.io.js" ></script > <script> var socket = io.connect('http://localhost'); socket.emit("getSomeData", function(data) { console.log(data); }); </script>
זה בגדול מה שחיפשתי. שימו לב שהקליינט שולח בקשה "getSomeDate", ומקבל את ה data שהוא רוצה.
פשוט וקל.@מנצפך אמר בשאלה כללית ב WebSocket:
https://stackoverflow.com/a/6756431
כאן יש אפשרות לעשות emit, ואז לחכות להאזין לתשובה שחוזרת.Server var io = require('socket.io').listen(80); io.sockets.on('connection', function (socket) { socket.on("getSomeData", function (name, fn) { fn({ data: "some random data" }); }); }); Client < script src = "http://localhost/socket.io/socket.io.js" ></script > <script> var socket = io.connect('http://localhost'); socket.emit("getSomeData", function(data) { console.log(data); }); </script>
זה בגדול מה שחיפשתי. שימו לב שהקליינט שולח בקשה "getSomeDate", ומקבל את ה data שהוא רוצה.
פשוט וקל.רק להוסיף
שאפשר גם לשלוח דאטא, רק לדאוג שהארגומנט האחרון יהיה הפונקציהvar socket = io.connect('http://localhost'); socket.emit("getSomeData", 'this is data', function(data) { console.log(data); });