当前位置: 首页 > news >正文

websocket实现简易聊天室

websocket实现简易聊天室

又做了一个关于websocket广播和在线人数统计的练习,实现一个简易的聊天室。

前端vue3

前端里的内容主要包含:
1.css的animation来实现公告从右到左的轮播。
2.websocket的onmessage里对不同消息的处理。

<template><div class="common-layout"><el-container><el-header><el-row><el-col :span="1"><div>公告:</div></el-col><el-col :span="20"><div class="scroll-container"><div class="text-scroll">公告信息</div></div></el-col><el-col :span="3" class="paddingleft20">在线人数:<span class="spanTip">{{onlineCount}}</span></el-col></el-row></el-header><el-container><el-aside><el-row v-for="(item, index) in onlineUsers" :key="index"><span class="onlinespan">{{item}}</span></el-row></el-aside><el-container><el-main v-html="othermessage"></el-main><el-footer><el-row><el-col :span="22"><el-input v-model="this.message" :rows="2" resize="none" type="textarea" @keyup.enter="sendMessage()"/></el-col><el-col :span="2" class="center"><el-button type="primary" @click="sendMessage()">发送</el-button></el-col></el-row></el-footer></el-container></el-container></el-container></div>
</template><script >
import { ref } from 'vue';
const socket = new WebSocket('ws://localhost:8080/chartroom');
const othermessage=ref('')
const onlineCount=ref(0)
const onlineUsers=ref([])
const own=ref('')
export default {name: 'Chart-Room',components: {},data(){return{message:'',othermessage,onlineCount,onlineUsers,own}},mounted(){this.connect();},unmounted(){this.beforeDestroy();},methods:{connect() {socket.onopen = function() {};socket.onmessage = function(event) {if(event.data.indexOf('onlineCount:')>-1){onlineCount.value=event.data.split(':')[1]}else if(event.data.indexOf('onlineUsers:')>-1){var userStr=event.data.split(':')[1];onlineUsers.value=userStr.split(',')}else if(event.data.indexOf('own')>-1){own.value=event.data.split(':')[1]}else{othermessage.value += "<div>"+event.data+"</div>"}};socket.onerror = function(event) {console.error('WebSocket error observed:', event);};},beforeDestroy() {if (socket) {socket.close();}},sendMessage() {if (socket.readyState === WebSocket.OPEN) {socket.send(own.value+":"+this.message);this.message=""}},}
}
</script><style scoped>.el-header{background-color:rgb(164, 172, 184);color: rgb(252, 252, 252);text-align: left;padding: 10px 15px;height:40px;}.el-aside{background-color:rgb(204, 209, 214);width:180px;height: 300px;}.el-main{background-color:rgb(246, 250, 253);padding: 10px 10px;white-space: pre-wrap;font-size: 14px;}.el-footer{margin:0px;padding:3px 3px;background-color:rgb(237, 241, 245);}.center{text-align: center;padding: 10px 5px;}.scroll-container {overflow: hidden;white-space: nowrap;text-align: right;}.text-scroll {display: inline-block;/** 实现从右到左的动画效果 */animation: scroll-right 30s linear infinite;}@keyframes scroll-right {0% {transform: translateX(100%);}100% {transform: translateX(-100%);}}.paddingleft20{padding-left: 20px;}.spanTip{color: rgb(252, 229, 179);}.onlinespan{margin:10px;color: rgb(85, 106, 128);}
</style>

后端java+mongodb

1.config配置

@Configuration
@EnableWebSocket
public class ChartConfig implements WebSocketConfigurer {@Overridepublic void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {registry.addHandler(chartHandler(), "/chartroom").setAllowedOrigins("*"); // 允许跨域}@Beanpublic ChartHandler chartHandler() {return new ChartHandler();}
}

2.处理连接成功后增加在线人数、断开连接后减少在线人数以及广播和单独发送消息。

public class ChartHandler extends TextWebSocketHandler {private static final Set<WebSocketSession> sessionsSet = Collections.synchronizedSet(new HashSet<>());/*** 接收消息*/@Overridepublic void handleTextMessage(WebSocketSession session, TextMessage message) throws IOException {//记录到mongodbMap<String, String> map = new HashMap<>();map.put("time", new Date().toString());String msg=message.getPayload().trim();map.put("message", msg.split(":")[1]);SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");String currentDate = sdf.format(new Date());MongoDBUtil.insertContent(currentDate, msg.split(":")[0], map);// 发送消息给客户端sendMessageToAll(message.getPayload());}/*** 连接后的处理*/@Overridepublic void afterConnectionEstablished(WebSocketSession session) throws Exception {sessionsSet.add(session);sendMessageToAll("onlineCount:" + sessionsSet.size());sendMessageToAll("onlineUsers:" + getListUsers());session.sendMessage(new TextMessage("own:【游客】"+session.getId().substring(0, 8)));}/*** 获取在线用户列表*/private String getListUsers() {List<String> usersList = new ArrayList<>();for(WebSocketSession item : sessionsSet){String userName="【游客】"+item.getId().substring(0, 8);if(!usersList.contains(userName)){usersList.add(userName);}}return String.join(",", usersList);}/*** 关闭连接后的处理*/@Overridepublic void afterConnectionClosed(WebSocketSession session, CloseStatus closeStatus) throws Exception {sessionsSet.remove(session);sendMessageToAll("onlineCount:" + sessionsSet.size());sendMessageToAll("onlineUsers:" + getListUsers());}/*** 广播发送消息*/private void sendMessageToAll(String message) {sessionsSet.forEach(item -> {try {item.sendMessage(new TextMessage(message));} catch (IOException e) {e.printStackTrace();}});}
}
http://www.lryc.cn/news/414437.html

相关文章:

  • vulhub-wordpress
  • 【机器学习算法基础】(基础机器学习课程)-10-逻辑回归-笔记
  • 自动驾驶行业知识汇总
  • C#根据反射操作对象
  • 打包python脚本(flask、jinja2)为exe文件
  • 嵌入式初学-C语言-练习三
  • 最新版Sonible Plugins Bundle v2024 winmac,简单智能,持续更新长期有效
  • J032_实现简易版的B/S架构
  • 【前端面试】五、框架
  • C语言 | Leetcode C语言题解之第316题去除重复字母
  • 本地部署 Llama-3-EvoVLM-JP-v2
  • Evaluating the Generation Capabilities of Large Chinese Language Models
  • YOLOv8添加注意力模块并测试和训练
  • 「Unity3D」自动布局LayoutElement、ContentSizeFitter、AspectRatioFitter、GridLayoutGroup
  • 【Golang 面试 - 进阶题】每日 3 题(十六)
  • Redis2
  • C语言--函数
  • Shell 编程的高级技巧和实战应用
  • VMWare虚拟机如何连接U盘
  • 【学习笔记】后缀自动机(SAM)
  • Godot的节点与场景
  • C++ 学习(2) ---- std::cout 格式化输出
  • 前端拿不到Long类型成员变量,用@JsonSerialize(using = ToStringSerializer.class)序列化一下
  • JWT登录校验流程
  • yarn安装和部署
  • Visual Studio的安装教程与使用方法
  • 一键换装软件哪个好?6个换装工具让你秒变穿搭达人
  • 【EtherCAT】Windows+Visual Studio配置SOEM主站——源码配置
  • GPTPDF深度解析:开源文档处理技术全攻略
  • 网络学习:应用层DNS域名解析协议