webSocket+Node+Js实现在线聊天(包含所有代码)

这篇文章主要介绍了如何使用 webSocket、Node 和 Js 实现在线聊天功能。 重要亮点

💻 技术选型:使用 Node.js 搭建服务器,利用 Express 框架和 Socket.io 库实现 WebSocket 通信。

📄 实现思路:通过建立数组存储聊天记录,在页面加载时发送连接请求,发送消息时广播给其他用户,前端使用 JQ 操作 DOM。

✍ 代码示例:提供了完整的代码示例,包括服务器端和客户端的实现。

webSocket+Node+Js实现在线聊天

一、首先我们需要创建一个index.js,写有关于node服务的逻辑代码,其中使用了express和socket。

二、这个时候,我们的node服务已经搭建好了,socket服务也启动了。
1、socket使用很简单
2、我们声明一个数组用来保存当前所有的聊天记录
在这里插入图片描述

3、首次进入页面的时候会主动发送socket信息
在这里插入图片描述

4、当我们发送消息的时候,其他人也可以收到对应的消息
在这里插入图片描述

5、前端使用了JQ用来操作dom,使用在线的socket连接后端的端口地址
在这里插入图片描述

三、输入用户名、输入要发送的文字、直接发送即可
在这里插入图片描述
四、对应代码

index.js

const express = require('express')
// const path = require('path')
const app = express()

let port = 3333
// app.use(express.static(path.join(__dirname, 'public')));
// app.get('/', (req, res, next) => {
//     res.writeHead(200, { 'Content-type': 'text/html;charset=utf-8' })
//     // res.end('欢迎来到express')
//     next()
// })
const server = app.listen(port, () => { console.log('成功启动express服务,端口号是' + port) })

//引入socket.io传入服务器对象 让socket.io注入到web网页服务
const io = require('socket.io')(server);
let arr = [{
    user:'系统消息',
    info:'恭喜链接websocket服务成功......'
}]
io.on('connect', (websocketObj) => {  //connect 固定的  
    console.log("====================")
    //链接成功后立即触发webEvent事件
    websocketObj.emit('webEvent', JSON.stringify(arr));
    //监听前端触发的 sendFunEvent  事件 
    websocketObj.on('sendFunEvent', (webres) => {
        console.log(webres, 'webreswebres')
        arr.push(webres)
        //触发所以的 sendFunEventCallBack 事件  让前端监听
        io.sockets.emit("sendFunEventCallBack", JSON.stringify(arr));
    })
})

index.html

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <!-- 通过script的方式引入 soctke.io -->
    <!-- //不成功就使用最新版本的 直接百度 cdn socket.io -->
    <script crossorigin="anonymous"
        integrity="sha512-xbQU0+iHqhVt7VIXi6vBJKPh3IQBF5B84sSHdjKiSccyX/1ZI7Vnkt2/8y8uruj63/DVmCxfUNohPNruthTEQA=="
        src="https://lib.baomitu.com/socket.io/4.6.1/socket.io.js"></script>
    <!-- 为了操作dom方便我也引入了jq -->
    <script src="https://cdn.jsdelivr.net/npm/jquery/dist/jquery.min.js"></script>
    <title>myWebsocket</title>
    <style>
        body {
            position: relative;
        }

        .zzzz {
            position: fixed;
            top: 20px;
            left: 20px;
        }
        .myBoxChild{
            margin-top: 60px;
        }
        .aaa{
            padding-left: 30px;
        }
    </style>
</head>

<body>
    <div class="myBox">
        <div class="zzzz">
            <input class="name" placeholder="用户名" type="text">
            <input class="inp" placeholder="请输入" type="text">
            <button onclick="sendFun()">发送</button>
        </div>
        <div class="myBoxChild"></div>
    </div>
    <script>
        //页面打开自动链接 http://localhost:3000 后端服务
        let mySocket = io("http://127.0.0.1:3333") //直接写后端服务地址
        //一直在监听webEvent 这个事件
        mySocket.on('webEvent', (res) => {
            window.alert(JSON.parse(res)[0].info)
        })
        mySocket.on('sendFunEventCallBack', (res) => {
            console.log(res, 'sendFunEventCallBackRes')
            let data = JSON.parse(res)
            let str = ''
            for (let i = 0; i < data.length; i++) {
                str += `<p class="aaa">${data[i].user}: ${data[i].info}</p>`
            }
            $('.myBoxChild')[0].innerHTML = str
        })

        //获取input的输入内容//将来传给服务器
        function sendFun() {
            if ($('.myBox .inp').val() != '') {
                mySocket.emit('sendFunEvent', {
                    info:$('.myBox .inp').val(),
                    user:$('.myBox .name').val()
                })
                setTimeout(() => {
                    $('.myBox .inp').val('')
                })
            } else {
                alert('输入字符')
                return
            }
        }
    </script>
</body>

</html>

全部代码:
webSocket+Node+Js实现在线聊天(包含所有代码)

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Uniapp中实现聊天功能,可以使用WebSocket协议进行实现。以下是一个简单的WebSocket聊天室的示例代码: 1. 创建聊天室页面 在uniapp项目中,创建一个聊天室页面,包括聊天内容展示区域和聊天输入区域。 2. 引入WebSocket聊天室页面中的`onLoad`生命周期函数中,引入WebSocket: ```javascript onLoad() { const socket = uni.connectSocket({ url: "ws://localhost:8080/chat", success: () => { console.log("WebSocket连接成功"); }, }); socket.onOpen(() => { console.log("WebSocket连接已打开"); }); socket.onMessage((res) => { console.log("收到服务器内容:" + res.data); // 处理收到的信息,将信息添加到聊天内容展示区域 }); socket.onClose(() => { console.log("WebSocket连接已关闭"); }); socket.onError((err) => { console.log("WebSocket连接出错:" + err); }); } ``` 其中,`url`为WebSocket服务端的地址,`onOpen`、`onMessage`、`onClose`和`onError`为WebSocket的事件监听函数。 3. 发送聊天内容 在聊天输入区域中,监听用户输入的内容,并通过WebSocket发送给服务端: ```javascript sendMessage() { const message = this.message; if (message) { uni.sendSocketMessage({ data: message, }); // 清空输入框 this.message = ""; } } ``` 其中,`this.message`为聊天输入框中的内容。 4. 服务端代码 WebSocket服务端可以使用Node.js的`ws`库进行实现。以下是一个简单的WebSocket服务端示例代码: ```javascript const WebSocket = require("ws"); const server = new WebSocket.Server({ port: 8080 }); server.on("connection", (socket) => { console.log("客户端已连接"); socket.on("message", (message) => { console.log("收到客户端内容:" + message); // 处理收到的信息,将信息广播给所有连接的客户端 server.clients.forEach((client) => { if (client.readyState === WebSocket.OPEN) { client.send(message); } }); }); socket.on("close", () => { console.log("客户端已关闭"); }); socket.on("error", (err) => { console.log("WebSocket连接出错:" + err); }); }); ``` 以上是一个简单的Uniapp实现聊天功能的示例代码,可以根据具体的需求进行修改和完善。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

六卿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值