html - 同一客户端上的多个 websocket 连接 - 服务器无法处理

标签 html node.js websocket

让我澄清一下,这有点复杂。 我正在实现一个表单来将数据插入数据库。

我在同一客户端有两个 websockets 连接,连接在同一个 Nodejs 服务器上。

用户在表单的“名称”文本字段中插入名称后会触发一个连接。将数据发送到服务器,服务器检查数据库该名称是否已存在并返回“该名称已存在。也许您正在插入已经存在的内容”。

如果表单的所有字段都不为空,则会触发另一个连接,并将数据发送到服务器以将其插入数据库中。

我认为在服务器端区分使用数组的不同连接是个好主意。如果数组的第一个元素是“name”,则调用 checkName 函数,如果是“insert”,则调用 insertInDB 函数。

我创建了两个小测试文件。他们不工作。连接已打开并且客户端发送数据。我在服务器和客户端都没有收到错误。但服务器从不响应。我在客户端没有得到预期的数字。无论如何,我认为这是不对的。这很复杂,希望代码对您有所帮助。

我正在尝试做的事情可能吗?有任何提示或替代方案吗?

谢谢

代码.... 服务器端

function WebSocketTest1(){
 var a=1;
 var b=2;
 var c = [a,b];

     var so = new WebSocket("ws://localhost:1337");

      so.onerror=function (evt) 
     {message.textContent = evt;}

     so.onopen = function(){
      message.textContent = "opened";
     so.send(c);
      message.textContent = "sended";
     }


     so.onmessage = function (evt) { 
        var received_msg = evt.data;
       document.getElementById("message").innerHTML=received_msg;
     }
}

function WebSocketTest2(){
 var d=3;
 var e=4;
 var f = [d,e];

     var sa = new WebSocket("ws://localhost:1337");

      sa.onerror=function (evt) 
     {message2.textContent = evt;}


     sa.onopen = function(){
     message2.textContent = "opened";
     sa.send(f);
     message2.textContent = "sended";
     }


     sa.onmessage = function (evt) {
         var received_msg = evt.data;
         document.getElementById("message2").innerHTML=received_msg;
}
}
</script>
</head>
 <input type="button" value="one" onClick="WebSocketTest1()"><br/>
  <input type="button" value="two" onClick="WebSocketTest2()"><br/>
<body>
  <div id="message"></div>
mesage2</br>
    <div id="message2"></div>
</body>
</html>

在服务器端,我列出了 session ,仅与特定 session 通信,代码找到 here 和服务器端(片段)

    var connections = {};
    var connectionIDCounter = 0;
    var connection = request.accept(null, request.origin);

   // Store a reference to the connection using an incrementing ID
    connection.id = connectionIDCounter ++;
    connections[connection.id] = connection;


    console.log((new Date()) + ' Connection accepted.');

   connection.on('message', function(message) {             
   var ja=message;
   if(ja[0]==1)
  {ja[1]=7;}        

  else if(ja[0]==3)
  {ja[1]=8;}
   }); 



    connection.on('close', function(reasonCode, description) {
    console.log((new Date()) + ' Peer ' + connection.remoteAddress + ' disconnected.');
    delete connections[connection.id];
    });
   });

// Send a message to a connection by its connectionID
function sendToConnectionId(connectionID, data) {
    var connection = connections[connectionID];
    if (connection && connection.connected) {
        connection.send(ja[1]);   
    }

最佳答案

我想知道为什么你需要 2 个连接。 打开一个连接并以 JSON 形式发送有效负载。

例如

var ws = new WebSocket("ws://localhost:1336");
ws.send(JSON.stringify({ command: "checkname", params: "xxxx"; });
ws.send(JSON.stringify({ command: "submit", params: { ... });

在服务器端,您只需解析有效负载并确定执行哪个命令。

关于html - 同一客户端上的多个 websocket 连接 - 服务器无法处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18041600/

相关文章:

jquery - 带有 jquery 效果问题的固定定位左侧菜单?

html - CSS:响应式背景图片高度

C# .net WebSocket 客户端永远不会断开连接

asynchronous - 如何像生成器一样使用异步协程?

node.js - 关于使用 websockets 和 node.js 编写可扩展的实时回合制策略游戏的建议

html - 不要使用 CSS 缩进第一段的第一行

javascript - 从兄弟元素中查找文本

node.js - 分配前使用变量 'newData' - TypeScript

javascript - 在使用 Require 的 JavaScript 上从 Grunt 运行 Jasmine 测试

javascript - Electron : can not find module jQuery