שאלה כללית ב WebSocket
-
@clickone אמר בשאלה כללית ב WebSocket:
@dovid
הרי יכול להיות 10 בקשות במקביל
אז במקום לעשות טוקן לכל בקשה ולבדוק מה חזר, הוא רוצה לוותר ע"ז.
לא נראה שיש דרך נורמלית לזה.
אלא אם כן הוא יכתוב או ימצא מחלקה שמטפלת בזה באופן חד פעמילא הבנתי. בכל מקרה כל ערוץ של לקוח זה אובייקט בזיכרון. והוא מבודד עם הפרטים הנדרשים. הוא לא צריך שום טוקנים ושום כלום.
-
@dovid אני חושב שקיבלתי את המידע שרציתי מהפוסט הזה.
שלמעשה לא ניתן לבצע (בצורה נורמלית) בקשת get משרת לקליינט. ואצטרך לממש את זה איכשהו.
תודה. -
@clickone אמר בשאלה כללית ב WebSocket:
@dovid
אבל אצל אותו לקוח יכול להיות 10 בקשות של קבציםנו אז שהבקשה תהיה please send file number 3.
תתארו סיפור שלם מהתחלה לסוף כי אני מרגיש שאנחנו לא על אותו גל. -
בשביל שהשרת יכול ליזום תקשורת יש להחזיק סוקט פתוח.
כלומר הלקוח יוזם פתיחת תקשורת, ואז היא נשארת פתוחה. והלקוח מאזין לקבלת מידע מהשרת.
כעת יש שתי נושאים למימוש, צד הלקוח וצד השרת.
צד הלקוח זה 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); });