דילוג לתוכן
  • דף הבית
  • קטגוריות
  • פוסטים אחרונים
  • משתמשים
  • חיפוש
  • חוקי הפורום
כיווץ
תחומים

תחומים - פורום חרדי מקצועי

💡 רוצה לזכור קריאת שמע בזמן? לחץ כאן!
  1. דף הבית
  2. תכנות
  3. שאלה כללית ב WebSocket

שאלה כללית ב WebSocket

מתוזמן נעוץ נעול הועבר תכנות
25 פוסטים 4 כותבים 1.7k צפיות 4 עוקבים
  • מהישן לחדש
  • מהחדש לישן
  • הכי הרבה הצבעות
תגובה
  • תגובה כנושא
התחברו כדי לפרסם תגובה
נושא זה נמחק. רק משתמשים עם הרשאות מתאימות יוכלו לצפות בו.
  • dovidD dovid

    בשביל שהשרת יכול ליזום תקשורת יש להחזיק סוקט פתוח.
    כלומר הלקוח יוזם פתיחת תקשורת, ואז היא נשארת פתוחה. והלקוח מאזין לקבלת מידע מהשרת.
    כעת יש שתי נושאים למימוש, צד הלקוח וצד השרת.
    צד הלקוח זה 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));
    }
    
    א מנותק
    א מנותק
    אהרן
    כתב ב נערך לאחרונה על ידי
    #21

    @dovid אמר בשאלה כללית ב WebSocket:

    wss.on('connection', c => clients.push(_ws)

    דוד
    מה זה _ws

    wss.on('connection', c => clients.push(_ws)
    
    dovidD תגובה 1 תגובה אחרונה
    0
    • א אהרן

      @dovid אמר בשאלה כללית ב WebSocket:

      wss.on('connection', c => clients.push(_ws)

      דוד
      מה זה _ws

      wss.on('connection', c => clients.push(_ws)
      
      dovidD מחובר
      dovidD מחובר
      dovid
      ניהול
      כתב ב נערך לאחרונה על ידי
      #22

      @אהרן אמר בשאלה כללית ב WebSocket:

      @dovid אמר בשאלה כללית ב WebSocket:

      wss.on('connection', c => clients.push(_ws)

      דוד
      מה זה _ws

      wss.on('connection', c => clients.push(_ws)
      

      טעות, צריך לשנות לc.

      • מנטור אישי בתכנות והמסתעף – להתקדם לשלב הבא!
      • בכל נושא אפשר ליצור קשר dovid@tchumim.com
      תגובה 1 תגובה אחרונה
      1
      • מנצפךמ מנותק
        מנצפךמ מנותק
        מנצפך
        כתב ב נערך לאחרונה על ידי מנצפך
        #23

        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 שהוא רוצה.
        פשוט וקל.

        א תגובה 1 תגובה אחרונה
        3
        • dovidD מחובר
          dovidD מחובר
          dovid
          ניהול
          כתב ב נערך לאחרונה על ידי
          #24

          socket.io זה מחלקה מנהלת לWebSocket.
          אני עניתי לך על הארכיטקטורה, שעימה אפשר לעשות הכל.

          • מנטור אישי בתכנות והמסתעף – להתקדם לשלב הבא!
          • בכל נושא אפשר ליצור קשר dovid@tchumim.com
          תגובה 1 תגובה אחרונה
          2
          • מנצפךמ מנצפך

            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 שהוא רוצה.
            פשוט וקל.

            א מנותק
            א מנותק
            אהרן
            כתב ב נערך לאחרונה על ידי
            #25

            @מנצפך אמר בשאלה כללית ב 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);
                        });
            
            תגובה 1 תגובה אחרונה
            2
            תגובה
            • תגובה כנושא
            התחברו כדי לפרסם תגובה
            • מהישן לחדש
            • מהחדש לישן
            • הכי הרבה הצבעות


            • 1
            • 2
            בא תתחבר לדף היומי!
            • התחברות

            • אין לך חשבון עדיין? הרשמה

            • התחברו או הירשמו כדי לחפש.
            • פוסט ראשון
              פוסט אחרון
            0
            • דף הבית
            • קטגוריות
            • פוסטים אחרונים
            • משתמשים
            • חיפוש
            • חוקי הפורום