socket的简单使用

模拟服务端

bash 复制代码
var Websocket = require('websocket').server
var http = require('http')

var httpServer =  http.createServer().listen(8080,function() {
    console.log('http://127.0.0.1:8080')
})

var wsServer = new Websocket({
    httpServer: httpServer,
    autoAcceptConnections: false
})

// 保存客户端的connection状态
var conArr = []

// 生成事件:request:事件名称 request:请求过来的数据
wsServer.on('request', function (request) {
    // 怎么拿到连接实例
   var connection =  request.accept();
   conArr.push(connection) // 保持
   connection.on('message', function (msg) {
       console.log(msg);
       for (let i = 0; i < conArr.length; i++) {    
           conArr[i].send(msg.utf8Data)
       }
    //    connection.send(msg.utf8Data) //返回至客户端
   })
})

模拟客户端

bash 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>

<body>
  <div id="msg"></div>
  <input type="text" id="text">
  <input type="button" value="发生" onclick="send()">
  <script>
    // web客户端的链接
    var websocket = new WebSocket('ws://127.0.0.1:8080')
    console.log(websocket.readyState);
    // readyState: 0:new 链接未建立,正在建立链接 1:链接建立成功 2:链接正在关闭 3:链接已经关闭
    // ws / wss
    // 链接建立是异步的
    websocket.onopen = function(){ // 类似于ajax,需要处理请求状态
      console.log(websocket.readyState);
    }
    function send() {
      var text = document.getElementById('text').value 
      websocket.send(text)
    }

    // 客户端接收服务器传过来的数据
    // 绑定一个服务器推送事件
    websocket.onmessage = function(back) {
      console.log(back.data);
    }
  </script>
</body>
</html>
相关推荐
小白探索世界欧耶!~16 分钟前
Vue2项目引入sortablejs实现表格行拖曳排序
前端·javascript·vue.js·经验分享·elementui·html·echarts
叫我一声阿雷吧2 小时前
JS实现响应式导航栏(移动端汉堡菜单)|适配多端+无缝交互【附完整源码】
开发语言·javascript·交互
GISer_Jing2 小时前
前端营销(AIGC II)
前端·react.js·aigc
NEXT062 小时前
深度解析 JWT:从 RFC 原理到 NestJS 实战与架构权衡
前端·typescript·nestjs
程序员林北北3 小时前
【前端进阶之旅】节流与防抖:前端性能优化的“安全带”与“稳定器”
前端·javascript·vue.js·react.js·typescript
寻星探路4 小时前
【前端基础】HTML + CSS + JavaScript 快速入门(三):JS 与 jQuery 实战
java·前端·javascript·css·c++·ai·html
未来之窗软件服务5 小时前
未来之窗昭和仙君(六十九)前端收银台行为异常检测—东方仙盟练气
前端·仙盟创梦ide·东方仙盟·昭和仙君
大叔编程奋斗记5 小时前
两个日期间的相隔年月计算
前端·salesforce
上海合宙LuatOS6 小时前
LuatOS核心库API——【io】 io操作(扩展)
java·服务器·前端·网络·单片机·嵌入式硬件·物联网
GISer_Jing7 小时前
Taro多端开发
前端·react.js·taro