如何搭建一个 websocket

环境:

安装依赖

bash 复制代码
yarn add socket.io

创建服务器

引入文件

特别注意: 涉及到 colors 的代码,请采取 console.log() 打印

js 复制代码
// 基础老三样
import http from "http";
import fs from "fs";
import { Server } from "socket.io";

// 下面2个是我本地开发的,你们可能没有
import colors from "colors-console";
import constant_color from "./colors.js";

createServer

请在当前目录下创建 index.html 文件。【客户端需要连接 socket.io

html 复制代码
<script src="/socket.io/socket.io.js"></script>

<script>
    constsocket = io();
</script>

服务端代码:

js 复制代码
const server = http.createServer((req, res) => {
    fs.readFile("./index.html", "utf-8", (err, data) => {
        if (err) {
            res.writeHead(500, "utf-8", e);
            res.end();
        }
        res.writeHead(200, {
            "Content-Type": "text/html"
        });
        res.end(data, "utf-8");
    });
});

websocket

简单判断客户端是否连接,断开。

js 复制代码
const io = new Server(server);

io.on("connection", socket => {
    console.succ("User connected.");

    // 用户断开连接
    socket.on("disconnect", () => {
        console.err("User disconnected.");
    })
});

server.listen(3000, "127.0.0.1");

启动服务器

bash 复制代码
yarn app

附录

再次提醒: 请去除所有 console.err console.succ colors 等有关颜色内容

项目结构:【它们都是同级目录,最顶层】

复制代码
D:.
│  app.js
│  colors.js
│  index.html
│  package.json
│  yarn.lock
│
└─node_modules

app.js 代码:

js 复制代码
import http from "http";
import fs from "fs";
import { Server } from "socket.io";
import colors from "colors-console";
import constant_color from "./colors.js";

// 重写 console.err 
console.err = (...msg) => {
    let str = "";
    for (let i = 0; i < msg.length; i++) {
        str += msg[i] + " ";
    }
    console.log(colors(constant_color.red, str));
}

// 定义 console.succ
console.succ = (...msg) => {
    let str = "";
    for (let i = 0; i < msg.length; i++) {
        str += msg[i] + " ";
    }
    console.log(colors(constant_color.green, str));
}

const server = http.createServer((req, res) => {
    fs.readFile("./index.html", "utf-8", (err, data) => {
        if (err) {
            res.writeHead(500, "utf-8", e);
            res.end();
        }
        res.writeHead(200, {
            "Content-Type": "text/html"
        });
        res.end(data, "utf-8");
    });
});

const io = new Server(server);

io.on("connection", socket => {
    console.succ("User connected.");

    // 用户断开连接
    socket.on("disconnect", () => {
        console.err("User disconnected.");
    })
});

server.listen(3000, "127.0.0.1");

console.log("Server running at \x1B[36m\x1B[4mhttp://127.0.0.1:3000\x1B[0m");

index.html 代码:

html 复制代码
<!DOCTYPE html>
<html lang="zh-CN">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="/socket.io/socket.io.js"></script>
</head>

<body>
    <h1>Hello Friend! 😀</h1>

    <script>
        const socket = io();
    </script>
</body>

</html>
相关推荐
非凡ghost5 分钟前
猫眼浏览器(Chrome内核增强版浏览器)官方便携版
前端·网络·chrome·windows·软件需求
阿拉斯加大闸蟹5 分钟前
[SIGCOMM‘25] Revisiting RDMA Reliability for Lossy Fabrics
网络·架构
嗨丶王哪跑17 分钟前
网络安全审计技术原理与应用
运维·网络·安全·web安全
RTC老炮20 分钟前
webrtc弱网-RobustThroughputEstimator源码分析与算法原理
网络·算法·webrtc
在路上看风景1 小时前
3.2 无连接传输: UDP
网络
雪碧聊技术1 小时前
关于springboot定时任务和websocket的思考
websocket·springboot定时任务
ErizJ1 小时前
WebSocket | 一点简单了解
网络·websocket·网络协议
晓梦.2 小时前
网络层协议之VRRP协议
网络·tcp/ip·智能路由器
IvanCodes3 小时前
七、Docker核心技术:深入理解网络模式 (Bridge, Host, None, Container)
网络·docker·容器
迎風吹頭髮3 小时前
UNIX下C语言编程与实践59-UNIX TCP 数据传输:send 与 recv 函数的使用与数据处理
c语言·网络·unix