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

相关推荐
不染尘.18 小时前
UDP客户服务器模型和UDP协议
服务器·网络·网络协议·计算机网络·udp
top_designer19 小时前
Illustrato:钢笔工具“退休”了?Text to Vector 零基础矢量生成流
前端·ui·aigc·交互·ux·设计师·平面设计
爬山算法20 小时前
Netty(21)Netty的SSL/TLS支持是如何实现的?
网络·网络协议·ssl
渡我白衣21 小时前
计算机组成原理(7):定点数的编码表示
汇编·人工智能·嵌入式硬件·网络协议·机器学习·硬件工程
Bruce_Liuxiaowei1 天前
网站敏感文件_目录大全(分类记忆+风险标注)
运维·网络·网络协议·http·网络安全·https
猛喝威士忌1 天前
【虚拟机】使用OpenWrt作为虚拟机集群的软路由(下)
linux·网络协议
2401_890443021 天前
传输层协议TCP
网络·网络协议·tcp/ip
玥轩_5211 天前
静态路由原理 及实验案例
网络·网络协议·网络安全·智能路由器·路由器·交换机
while(1){yan}1 天前
数据链路层与物理层
java·网络·网络协议
樱桃园园长1 天前
【Three.js 实战】手势控制 3D 奢华圣诞树 —— 从粒子系统到交互实现
javascript·3d·交互