一个基于 Spring Cloud + Vue + Socket.IO 的在线聊天网站,不来体验一下吗?

前言

2022年8月1日,经过一系列的准备工作,这个充满 BUG 的神奇网站在今天发布上线了。因为网站目前的主要功能是在线聊天,所以暂且就先叫它 EasyChat 吧。

EasyChat 是一个可以在线聊天的即时通讯平台,完全由个人设计和开发,初衷主要是觉得好玩儿,顺便学习一些新东西,所以网站有些简陋,属实是本人的能力和财力有限。网站没有任何付费内容,所有内容完全免费,欢迎大家使用体验,也期待大佬们的交流与反馈。

体验地址:https://toollong.icu(网站已于 2023.08.18 下线,运行时长 382 天)

注意: 本网站仅供学习交流使用,由于网站的安全保障和加密措施并不完善,请勿在网站中输入敏感信息,避免信息泄露的风险。

功能介绍(v1.0.1)

关于功能的具体实现由于内容太多,就不在这里详细阐述了,可以去看一下源码,有什么疑问和建议也可以随时交流。下面是已经实现的功能:

  • 注册
  • 登录
  • 找回密码
  • 添加聊天
  • 删除聊天
  • 发送文本消息
  • 发送 Emoji 表情(Windows 7 可能无法正常显示)
  • 发送图片(批量发送)
  • 发送文件(同步发送,有点慢)
  • 新消息通知(有提示音)
  • 搜索用户
  • 修改好友备注
  • 好友申请
  • 好友验证
  • 好友删除(单向删除)
  • 验证消息通知(有提示音)
  • 查看资料
  • 编辑资料
  • 设置(头像、隐身、标签、修改密码)
  • 夜间模式
  • 小抽屉(搜一搜、日历)

技术栈(v1.0.1)

  • 前端使用 Vue CLI 开发,后端使用 Java 开发。

  • 前端:Vue 3、Vue Router、Vuex、Element Plus、Socket.IO、Axios、VueUse…

  • 后端:Spring Cloud、Nacos、MyBatis-Plus、Netty-socketio、MinIO、Gson、MySQL、Redis、Docker…

源码

前端代码

后端代码

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
好的,我可以为你提供基于Vue3的setup socket.io实现聊天的页面以及完整的聊天功能的代码。下面是代码示例: 首先,你需要在你的Vue项目中安装socket.io-client: ```bash npm install socket.io-client ``` 然后在你的Vue组件中引入socket.io-client并在setup函数中使用它来连接服务器: ```javascript import { ref, onMounted } from 'vue'; import io from 'socket.io-client'; export default { setup() { const messages = ref([]); const socket = io('http://localhost:3000'); onMounted(() => { socket.on('message', (message) => { messages.value.push(message); }); }); function sendMessage(message) { socket.emit('message', message); } return { messages, sendMessage }; } } ``` 在这个示例中,我们使用了Vue3的ref和onMounted函数来创建一个响应式的messages数组,并在组件挂载后使用socket.on函数监听服务器发送的message事件,并将接收到的消息push到messages数组中。我们还创建了一个sendMessage函数,用于向服务器发送消息。 接下来,我们可以在模板中使用messages数组和sendMessage函数来实现聊天界面: ```html <template> <div> <div v-for="message in messages" :key="message.id"> <p>{{ message.sender }}: {{ message.text }}</p> </div> <form @submit.prevent="sendMessage(newMessage)"> <input type="text" v-model="newMessage" /> <button type="submit">Send</button> </form> </div> </template> ``` 在这个示例中,我们使用v-for指令循环渲染messages数组中的每个消息,并在模板中使用一个表单来允许用户发送新消息。我们使用v-model指令将表单的输入绑定到newMessage变量,并在表单提交时调用sendMessage函数来向服务器发送新消息。 最后,我们需要在服务器端实现接收和处理消息的逻辑。以下是一个简单的Node.js服务器端代码示例: ```javascript const http = require('http'); const socketIo = require('socket.io'); const server = http.createServer(); const io = socketIo(server); io.on('connection', (socket) => { console.log(`Client connected: ${socket.id}`); socket.on('message', (message) => { io.emit('message', { id: Date.now(), sender: 'User', text: message }); }); socket.on('disconnect', () => { console.log(`Client disconnected: ${socket.id}`); }); }); server.listen(3000, () => { console.log('Server started'); }); ``` 在这个示例中,我们使用Node.js创建了一个HTTP服务器,并使用socket.io创建了一个WebSocket服务器。在WebSocket连接建立时,我们使用socket.on函数监听客户端发送的message事件,并使用io.emit函数将接收到的消息广播给所有连接的客户端。当连接断开时,我们使用socket.on函数监听disconnect事件。 这就是一个基于Vue3的setup socket.io实现聊天的页面以及完整的聊天功能的代码示例。希望能对你有所帮助!
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

toollong

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

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

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

打赏作者

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

抵扣说明:

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

余额充值