webSocket前后端交互pc端版

前端代码

javascript 复制代码
<!--
 * @Author: 第一好帅@宝
 * @Date: 2023-08-29 16:12:26
 * @LastEditTime: 2023-08-29 16:54:50
 * @FilePath: \websocket\ceshi.html
-->
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <div class="msg"></div>
    <input type="text">
    <button>发送</button>
    <button class="bu">关闭连接</button>
    <div class="box"></div>
    <script>
        let inp = document.querySelector('input')
        let but = document.querySelector('button')
        let bu = document.querySelector('.bu')
        let ws = new WebSocket('ws://localhost:8001')
        console.log(ws);
        //初始化连接
        ws.onopen = function () {
            document.querySelector('.msg').innerHTML = '<h1>连接成功!</h1>'
            console.log('连接成功触发函数');
            ws.send('第一次连接')
        }
        //服务器关闭
        ws.onclose = function (e) {
            document.querySelector('.msg').innerHTML = '<h1>服务器关闭!</h1>'
            console.log('服务器关闭');
        }
        //连接出错
        ws.onerror = function (e) {
            document.querySelector('.msg').innerHTML = '<h1>连接出错了!</h1>'
            console.log('连接出错了');
        }
        //服务器返回数据触发函数
        ws.onmessage = function (e) {
            console.log(e.data);
            document.querySelector('.box').innerHTML = e.data
        }
        //向后端发送消息
        but.addEventListener('click', function () {
            if (inp.value.trim() != '') {
                ws.send(inp.value)
            }
        })
        //断开连接
        bu.addEventListener('click', function () {
            ws.close()
        })
    </script>
</body>

</html>

后端代码,使用nodejs

javascript 复制代码
npm i nodejs-websocket
javascript 复制代码
/*
 * @Author: 第一好帅@宝
 * @Date: 2023-08-29 15:52:49
 * @LastEditTime: 2023-08-29 16:48:17
 * @FilePath: \node\node.js
 */
var ws = require('nodejs-websocket');
 
console.log("开始建立连接...");
 
var server = ws.createServer(function (conn) {
 
  conn.on("connect", function (code) {
    console.log("开启连接" + code);
  });
 
  conn.on("text", function (result) {
    console.log("收到的信息为:" + result); //由Webtest.html中传来data 
    let a=result
    if (result == 1) {
      a="飞哥" //发送"success"至Webtest.html
    } else if (result == 2) {
      a="帆姐" //发送"success"至Webtest.html
    } else if (result == 3) {
      a='东哥'
    }else if(result==4){
      a="阳哥"
    }
 
//向前端发送消息
    conn.sendText('服务器返回数据:'+a);
  });
 
  conn.on("close", function (code) {
    console.log("关闭连接")
  });
 
  conn.on("error", function (code) {
    console.log("异常关闭")
  });
}).listen(8001);
 
console.log("WebSocket连接建立完毕");

运行 node xx.js

相关推荐
北京耐用通信11 分钟前
耐达讯自动化Profibus总线光纤中继器:破解石油化工分析仪器通讯难题
网络·人工智能·科技·物联网·网络协议·自动化·信息与通信
e***985725 分钟前
TCP/IP协议栈全解析:从基础到未来
网络·网络协议·tcp/ip
乾元1 小时前
构建你的个人「网络 AI 实验室」——硬件、模拟器与数据集清单
运维·网络·人工智能·网络协议·架构
深圳市恒讯科技1 小时前
在带有HTTPS的VPS上安装和部署n8n的最简单方法
网络协议·http·https
测试19982 小时前
用Postman测WebSocket接口
自动化测试·软件测试·python·websocket·测试工具·接口测试·postman
YYYing.2 小时前
【计算机网络 | 第四篇】路由与NAT技术
运维·服务器·网络·网络协议·计算机网络
科技块儿2 小时前
【游戏防外挂】同一IP多账号登录?IP地址查询定位快速识别工作室
网络协议·tcp/ip·游戏
前端达人3 小时前
WebSocket vs SSE深度对比分析
网络·websocket·网络协议
Tandy12356_4 小时前
手写TCP/IP协议栈——TCP数据接收
c语言·网络·网络协议·tcp/ip·计算机网络
fy zs4 小时前
TCP/IP 协议栈深度解析
网络·网络协议·tcp/ip