如何搭建一个 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>
相关推荐
YuMiao11 小时前
gstatic连接问题导致Google Gemini / Studio页面乱码或图标缺失问题
服务器·网络协议
Jony_3 天前
高可用移动网络连接
网络协议
chilix3 天前
Linux 跨网段路由转发配置
网络协议
DianSan_ERP5 天前
电商API接口全链路监控:构建坚不可摧的线上运维防线
大数据·运维·网络·人工智能·git·servlet
呉師傅5 天前
火狐浏览器报错配置文件缺失如何解决#操作技巧#
运维·网络·windows·电脑
gihigo19985 天前
基于TCP协议实现视频采集与通信
网络协议·tcp/ip·音视频
2501_946205525 天前
晶圆机器人双臂怎么选型?适配2-12寸晶圆的末端效应器有哪些?
服务器·网络·机器人
linux kernel5 天前
第七部分:高级IO
服务器·网络
数字护盾(和中)5 天前
BAS+ATT&CK:企业主动防御的黄金组合
服务器·网络·数据库
~远在太平洋~5 天前
Debian系统如何删除多余的kernel
linux·网络·debian