vue和node使用websocket实现数据推送,实时聊天

需求:node做后端根据websocket,连接数据库,数据库的字段改变后,前端不用刷新页面也能更新到数据,前端也可以发送消息给后端,后端接受后把前端消息做处理再推送给前端展示

1.初始化node,生成package.json和package-lock.js

复制代码
 npm init -y

2.安装express、socket.io、cors

3.创建app.js并编写代码

使用node ./websocket.js运行项目

复制代码
npm install express socket.io cors -S

建立websocket.js

复制代码
const app = require('express')();
const http = require('http').createServer(app);
const io = require('socket.io')(http);
const fs = require('fs');
const cors = require('cors');
// 使用 cors 中间件允许跨域请求
// 配置跨域选项
const corsOptions = {
  origin: '*', // 指定允许的来源
  methods: ['GET', 'POST'], // 允许的请求方法
  credentials: true // 允许发送凭据(如 cookies)
};
app.use(cors(corsOptions));
// 创建数据库连接
const mysql = require('mysql');
const connection = mysql.createConnection({
  host: 'localhost',//数据库连接域名
  user: 'root',//数据库账号
  password: '123456',//密码
  database: 'graduation_design'//要连接的数据库名
});
connection.connect();
 
// 监听客户端连接事件
io.on('connection', (socket) => {
  console.log('A client connected');
  //查询表
  connection.query('SELECT * FROM shelves', (error, results) => {
    if (error) throw error;
    //数据推送到前端
    socket.emit('data', results);
  },)
  // 发送数据到客户端
  setInterval(() => {
    // 查询数据库并发送数据到客户端
    connection.query('SELECT * FROM shelves', (error, results) => {
      if (error) throw error;
      socket.emit('data', results);
    },)
  }, 60 * 1000);
  //接收到客户端的消息后再推送给客户端
  socket.on('message', (message) => {
    console.log('接收到客户端消息:', message);
    socket.emit("messagedata", message);
  })
 
  // 监听客户端断开连接事件
  socket.on('disconnect', () => {
    console.log('A client disconnected');
  });
});
 
// 启动服务器
http.listen(3000, () => {
  console.log('WebSocket server is running on port 3333');
});

4.前端使用socket.io-client

复制代码
npm install socket.io-client

在需要使用websocket连接的页面引入

复制代码
<template>
    <div class="content-box">
        <div class="container">
            {{ data }}
            <el-button @click="connectWebscoket">连接websocket</el-button>
            <el-button @click="gasong">发送</el-button>
            <el-button @click="stop">停止连接</el-button>
            <hr />
            {{ msgdata }}
        </div>
    </div>
</template>
 
<script>
import io from 'socket.io-client'
let socket = null
export default {
    data() {
        return {
            data: null,
            msgdata: ''
        }
    },
    mounted() {},
    methods: {
        connectWebscoket() {
            // 解决跨域问题
            socket = io('http://localhost:3333', {
                transports: ['websocket'],
                withCredentials: true, //白名单
                extraHeaders: {
                    //请求头
                    'Access-Control-Allow-Origin': 'http://localhost:8080'
                }
            })
            socket.on('data', (data) => {
                this.data = data
            })
            socket.on('messagedata', (msg) => {
                this.msgdata = msg
            })
        },
        gasong() {
            socket.send('Hello from client!')
        },
        stop() {
            socket.close()
        }
    }
}
</script>
 
<style lang="scss" scoped></style>

此时已经建立好websocket的连接

相关推荐
海天胜景9 分钟前
无法加载文件 E:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
MingT 明天你好!11 分钟前
在vs code 中无法运行npm并报无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查
前端·npm·node.js·visual studio code
老兵发新帖17 分钟前
pnpm 与 npm 的核心区别
前端·npm·node.js
超级土豆粉18 分钟前
怎么打包发布到npm?——从零到一的详细指南
前端·npm·node.js
OpenTiny社区23 分钟前
TinyEngine 2.5版本正式发布:多选交互优化升级,页面预览支持热更新,性能持续跃升!
前端·低代码·开源·交互·opentiny
声声codeGrandMaster1 小时前
Django框架的前端部分使用Ajax请求一
前端·后端·python·ajax·django
sunbyte1 小时前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Expanding Cards (展开式卡片)
javascript·vue.js·ecmascript
重生之后端学习2 小时前
02-前端Web开发(JS+Vue+Ajax)
java·开发语言·前端·javascript·vue.js
繁依Fanyi3 小时前
用 CodeBuddy 实现「IdeaSpark 每日灵感卡」:一场 UI 与灵感的极简之旅
开发语言·前端·游戏·ui·编辑器·codebuddy首席试玩官
黄鹂绿柳5 小时前
Vue+Vite学习笔记
vue.js·笔记·学习