栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Vue.js

SpringBoot+Vue+WebSocket 实现在线聊天

Vue.js 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot+Vue+WebSocket 实现在线聊天

一、前言

本文将基于 SpringBoot + Vue + WebSocket 实现一个简单的在线聊天功能

页面如下:

在线体验地址:http://www.zhengqingya.com:8101

二、SpringBoot + Vue + WebSocket 实现在线聊天 1、引入websocket依赖

    org.springframework.boot
    spring-boot-starter-websocket

2、websocket 配置类
@Configuration
public class WebSocketConfig {
    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
 return new ServerEndpointExporter();
    }
}
3、websocket 处理类Controller
@Slf4j
@Component
@ServerEndpoint("/groupChat/{sid}/{userId}")
public class WebSocketServerController {

    
    private static ConcurrentHashMap> groupMemberInfoMap = new ConcurrentHashMap<>();
    
    private static ConcurrentHashMap> onlineUserMap = new ConcurrentHashMap<>();

    
    @OnMessage
    public void onMessage(@PathParam("sid") String sid, @PathParam("userId") Integer userId, String message) {
 List sessionList = groupMemberInfoMap.get(sid);
 Set onlineUserList = onlineUserMap.get(sid);
 // 先一个群组内的成员发送消息
 sessionList.forEach(item -> {
     try {
  // json字符串转对象
  MsgVO msg = JSONObject.parseObject(message, MsgVO.class);
  msg.setCount(onlineUserList.size());
  // json对象转字符串
  String text = JSONObject.toJSONString(msg);
  item.getBasicRemote().sendText(text);
     } catch (IOException e) {
  e.printStackTrace();
     }
 });
    }

    
    @OnOpen
    public void onOpen(Session session, @PathParam("sid") String sid, @PathParam("userId") Integer userId) {
 List sessionList = groupMemberInfoMap.computeIfAbsent(sid, k -> new ArrayList<>());
 Set onlineUserList = onlineUserMap.computeIfAbsent(sid, k -> new HashSet<>());
 onlineUserList.add(userId);
 sessionList.add(session);
 // 发送上线通知
 sendInfo(sid, userId, onlineUserList.size(), "上线了~");
    }


    public void sendInfo(String sid, Integer userId, Integer onlineSum, String info) {
 // 获取该连接用户信息
 User currentUser = ApplicationContextUtil.getApplicationContext().getBean(UserMapper.class).selectById(userId);
 // 发送通知
 MsgVO msg = new MsgVO();
 msg.setCount(onlineSum);
 msg.setUserId(userId);
 msg.setAvatar(currentUser.getAvatar());
 msg.setMsg(currentUser.getNickName() + info);
 // json对象转字符串
 String text = JSONObject.toJSONString(msg);
 onMessage(sid, userId, text);
    }

    
    @OnClose
    public void onClose(Session session, @PathParam("sid") String sid, @PathParam("userId") Integer userId) {
 List sessionList = groupMemberInfoMap.get(sid);
 sessionList.remove(session);
 Set onlineUserList = onlineUserMap.get(sid);
 onlineUserList.remove(userId);
 // 发送离线通知
 sendInfo(sid, userId, onlineUserList.size(), "下线了~");
    }

    
    @OnError
    public void OnError(Throwable error) {
 log.info("Connection error");
    }
}
4、websocket 消息显示类
@Data
@ApiModel(description = "websocket消息内容")
public class MsgVO {

    @ApiModelProperty(value = "用户id")
    private Integer userId;

    @ApiModelProperty(value = "用户名")
    private String username;

    @ApiModelProperty(value = "用户头像")
    private String avatar;

    @ApiModelProperty(value = "消息")
    private String msg;

    @ApiModelProperty(value = "在线人数")
    private int count;

}
5、前端页面

温馨小提示:当用户登录成功之后,可以发起websocket连接,存在store中…

下面只是单页面的简单实现






本文案例demo源码

https://gitee.com/zhengqingya/xiao-xiao-su

转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号