`

175. Spring Boot WebSocket:单聊

阅读更多

 

【视频&交流平台】

à SpringBoot视频

http://study.163.com/course/introduction.htm?courseId=1004329008&utm_campaign=commission&utm_source=400000000155061&utm_medium=share

à SpringCloud视频

http://study.163.com/course/introduction.htm?courseId=1004638001&utm_campaign=commission&utm_source=400000000155061&utm_medium=share

à Spring Boot源码

https://gitee.com/happyangellxq520/spring-boot

à Spring Boot交流平台

http://412887952-qq-com.iteye.com/blog/2321532

 

需求缘起:

       在前面的文章中已经实现了群聊,这里也简单介绍下单聊。这里使用session.getId()中的id作为唯一的消息通道(这里我们称为通讯的频道号), session.getId()是一个递增的数字,从0开始,递增1,2,3… 实际中并不会使用这个id作为标识,这里只是为了讲解方便。

效果展示:

先看下最终实现的效果,如下图:

 

悟空消息:



 

 

 

师傅消息:



 

 

 

八戒消息:



 

一、服务端调整

1.1  创建一个Socket消息对象SocketMsg

       这里我们就不能使用简单的文本消息进行消息的发送了,我们使用json进行消息的发送。所以需要先创建一个消息对象,里面包含了消息发送者,消息接受者,消息类型(单聊还是群聊),还是就是消息,如下:

com.kfit.socket.SocketMsg

package com.kfit.socket;
 
public class SocketMsg {
       private int type;//聊天类型0:群聊,1:单聊.
       private String fromUser;//发送者.
       private String toUser;//接受者.
       private String msg;//消息
       public int getType() {
              return type;
       }
       public void setType(inttype) {
              this.type = type;
       }
       public String getFromUser() {
              return fromUser;
       }
       public void setFromUser(String fromUser) {
              this.fromUser = fromUser;
       }
       public String getToUser() {
              returntoUser;
       }
       public void setToUser(String toUser) {
              this.toUser = toUser;
       }
       public String getMsg() {
              returnmsg;
       }
       public void setMsg(String msg) {
              this.msg = msg;
       }
}

 

 

1.2  调整建立连接的方法(MyWebSocket

       这里主要是要使用一个map对象保存频道号和session之前的关系,之后就可以通过频道号获取session,然后使用session进行消息的发送。

定义一个map对象:

//用来记录sessionId和该session进行绑定 
 private static Map<String,Session> map = new HashMap<String, Session>(); 

 

 

修改连接的方法onOpen

       在建立连接的时候,就保存频道号(这里使用的是session.getId()作为频道号)和session之间的对应关系:

    @OnOpen
    public void onOpen(Session session,@PathParam("nickname") String nickname) {
        this.session = session;
        this.nickname = nickname;
        map.put(session.getId(), session);
       
        webSocketSet.add(this);     //加入set中
        System.out.println("有新连接加入!当前在线人数为" + webSocketSet.size());
        this.session.getAsyncRemote().sendText(this.nickname+"上线了"+"(他的频道号是"+session.getId()+")");
    }

 

 

修改消息发送的方法 onMessage

       从客户端传过来的数据是json数据,所以这里使用jackson进行转换为SocketMsg对象,然后通过socketMsgtype进行判断是单聊还是群聊,进行相应的处理:

@OnMessage
    public void onMessage(String message, Session session,@PathParam("nickname") String nickname) {
        System.out.println("来自客户端的消息:" + message);
 
        ObjectMapper objectMapper = new ObjectMapper();
        SocketMsg socketMsg;
              try {
                     socketMsg = objectMapper.readValue(message, SocketMsg.class);
                     if(socketMsg.getType() == 1){
                            //单聊.需要找到发送者和接受者.
                           
                            socketMsg.setFromUser(session.getId());//发送者.
                            Session fromSession = map.get(socketMsg.getFromUser());
                            Session toSession = map.get(socketMsg.getToUser());
                            //发送给接受者.
                            if(toSession != null){
                                   //发送给发送者.
                                   fromSession.getAsyncRemote().sendText(nickname+":"+socketMsg.getMsg());
                                   toSession.getAsyncRemote().sendText(nickname+":"+socketMsg.getMsg());
                            }else{
                                   //发送给发送者.
                                   fromSession.getAsyncRemote().sendText("系统消息:对方不在线或者您输入的频道号不对");
                            }
                     }else{
                            //群发消息
                      broadcast(nickname,socketMsg);
                     }
              } catch (JsonParseException e) {
                     // TODO Auto-generated catch block
                     e.printStackTrace();
              } catch (JsonMappingException e) {
                     // TODO Auto-generated catch block
                     e.printStackTrace();
              } catch (IOException e) {
                     // TODO Auto-generated catch block
                     e.printStackTrace();
              }
    }

 

 

二、客户端调整

2.1 加入频道号输入框

       提供用户输入频道号进行单聊:

消息:<input id="text" type="text" />
频道号<input id="toUser" type="text" />
<button onclick="send()">发送消息</button>

 

 

2.2 修改消息发送方法

       这里使用了js对象进行消息的传递,这里使用JSON.stringifyjson对象转换为json字符串,如下代码:

//发送消息
       function send() {
              //获取输入的文本信息进行发送
              var message = document.getElementById('text').value;
              var toUser = document.getElementById('toUser').value;
              var socketMsg = {msg:message,toUser:toUser};
              if(toUser == ''){
                     //群聊.
                     socketMsg.type = 0;
              }else{
                     //单聊.
                     socketMsg.type = 1;
              }
             
              websocket.send(JSON.stringify(socketMsg));
       }

 

       好了,到这里就可以实现了单聊+群聊的效果。

 

三、新问题的提出

       上面虽然可以实现单聊的方式,但是在具体的实际场景中,想要知道对方的频道号好像不是那么容易的哦,那么这个要怎么解决呢?大家在玩QQ群的时候,应该都用过聊天界面中的右边的群成员吧,对头,就是要实现一个在线群成员列表的功能,这样用户在操作的时候就可以直接通过点击某个在线的用户进行聊天了。博主,你会实现嘛?^_^,博主还暂时没有这个计划,其实看懂了上面的代码之后,要实现在线群成员列表也不是很难的事情了。

 

 

四、源代码

 

       最后奉上源代码。大家可以下载源代码玩玩!

访问地址:https://gitee.com/happyangellxq520/spring-boot 找到spring-boot-websocket-2017,直接下载即可运行。

 

  • 大小: 15.2 KB
  • 大小: 13.3 KB
  • 大小: 15.4 KB
分享到:
评论

相关推荐

    如何使用Spring Boot 3.X + WebSocket来实现推送消息功能

    如何使用Postman来发送数据到后端Spring Boot应用程序,并使用WebSocket建立实时通信通道,以便后端应用程序可以向Postman推送消息。 学会这个方法,就能缩短你的项目开发周期,以及提高你的开发效率。如果提出您的...

    Spring-Boot-Reference-Guide, Spring Boot Reference Guide中文翻译 -《Spring Boot参考指南》.zip

    《Spring Boot参考指南》是Spring Boot开发者的重要参考资料,它详细阐述了Spring Boot框架的核心特性、配置方式、自动配置原理以及如何构建微服务应用等关键知识点。Spring Boot是Java开发领域中一个极其流行的轻量...

    spring-boot实战PDF 完整版和随书源码.7z

    在《Spring Boot实战》这本书中,作者会详细讲解如何使用Spring Boot创建RESTful服务、数据库访问、集成WebSocket、安全控制、测试策略等内容。随书源码涵盖了所有示例项目,读者可以按照书中步骤逐步实践,通过动手...

    38. Spring Boot分布式Session状态保存Redis【从零开始学Spring Boot】

    在Spring Boot应用中,随着系统复杂度的增加,单一服务器往往无法满足高并发、高可用的需求,因此我们会采用分布式架构。然而,在分布式环境下,传统的基于HTTP Session的状态管理方式会遇到问题,因为每个服务器都...

    spring boot+websocket

    在本文中,我们将深入探讨如何在Spring Boot框架中集成WebSocket技术,以便实现实时通信功能。结合jQuery在前端的应用,可以构建出一个高效、实时的Web应用。首先,让我们了解Spring Boot和WebSocket的基本概念。 ...

    Spring Boot整合websocket实现群聊,点对点聊天,图片发送,音频发送

    Spring Boot作为Java生态中的微服务框架,提供了方便地集成WebSocket的功能,使得开发者能够轻松构建实时交互的应用,如群聊、点对点聊天以及发送图片和音频等富媒体消息。 首先,集成WebSocket到Spring Boot项目中...

    如何利用 Spring Boot 3.X 和 WebSocket 来实现消息推送功能,并实现动态开启、关闭和取消定时任务的功能?

    概要:本文介绍如何使用 Spring Boot 3.X 和 WebSocket 实现消息推送,并动态开启、关闭和取消定时任务。通过WebSocket实现实时通信,结合定时任务管理,可实现灵活的消息推送和任务控制。 使用人群:适合有Spring ...

    spring boot+websocket前后端简单demo

    在本文中,我们将深入探讨如何使用Spring Boot和WebSocket技术创建一个简单的前后端交互示例。Spring Boot是Java领域中广泛使用的微服务框架,它简化了Spring应用的初始设置和配置。而WebSocket则是一种在客户端和...

    Spring-websocket-master.zip

    1. **配置**:Spring Boot的配置文件(如application.yml或application.properties)中会配置WebSocket的相关设置,包括WebSocket的路径、使用的WebSocket服务器实现(如Tomcat或Jetty)等。 2. **WebSocket配置**:...

    spring+websocketdemo

    1. **Spring WebSocket集成**:在Spring Boot项目中,可以通过添加`spring-boot-starter-websocket`依赖来启用WebSocket支持。然后,在配置类中配置WebSocket消息代理,包括设置STOMP(简单消息传输协议)作为消息...

    spring-boot-websocket-client代码示例

    在本文中,我们将深入探讨如何使用Spring Boot构建一个WebSocket客户端。`spring-boot-websocket-client`这个项目就是一个关于此主题的代码示例。Spring Boot作为Java生态中的一个热门框架,简化了创建独立、生产...

    spring boot websocket例子

    spring boot websocket例子,实现socket连接,关闭,发送消息功能,运行Application.java运行项目,访问地址http://localhost:8080/socket.html

    SpringBoot2.0开发WebSocket应用完整示例

    在本示例中,我们将探讨如何使用Spring Boot 2.0开发WebSocket应用程序。WebSocket协议是一种在客户端和服务器之间实现全双工通信的标准,允许数据实时双向传输,这在需要实时更新的应用场景,如聊天应用、在线游戏...

    Spring Boot 2.1.3 官方文档

    Spring Boot是Java开发领域的一款非常流行的微服务框架,它极大地简化了Spring应用的初始化和配置过程,使得开发者能够快速地创建独立运行的应用。Spring Boot 2.1.3是该框架的一个稳定版本,包含了丰富的特性与改进...

    spring-boot-2.4.x.zip

    3. 整合WebSocket:通过源码学习,可以了解如何在Spring Boot中启用WebSocket,实现实时通信。 4. 微服务治理:利用Spring Cloud与Spring Boot结合,构建微服务架构,源码分析有助于理解服务注册、发现、熔断等机制...

    spring-boot-starter-websocket.zip

    对于“spring-boot-starter-websocket.zip”这个压缩包,我们可以推断它包含了Spring Boot项目中用于WebSocket通信的相关起步依赖。WebSocket是一种在客户端和服务器之间建立长连接的协议,使得实时双向通信成为可能...

    Javaee开发 spring boot实战

    《JavaEE开发的颠覆者:Spring Boot实战》一书深入探讨了Spring Boot这一JavaEE开发领域的革新框架。Spring Boot以其简化配置、快速启动和高效运行的特性,成为了现代企业级应用开发的首选工具。本节将围绕Spring ...

    spring-boot-websocket.rar

    标题中的“spring-boot-websocket.rar”表明这是一个关于Spring Boot集成WebSocket技术的压缩包资源。Spring Boot是Java领域中一个流行的微服务框架,它简化了创建独立的、生产级的基于Spring的应用程序。WebSocket...

    基于spring-boot 2.x扩展WebSocket,支持细粒度控制.rar

    一、前言 WebSocket是一种在单个TCP连接上进行全双工通信的协议。WebSocket通信协议于2011年被IETF定为标准RFC 6455...spring boot2.x整合websocket服务端; websocket客户端java代码版; websocket客户端HTML网页版。

    SpringBoot整合WebSocket+nacos注册中心

    1. 添加WebSocket依赖:在`pom.xml`中引入Spring Websocket相关依赖,如`spring-boot-starter-websocket`。 2. 配置WebSocket:在`application.yml`或`application.properties`中配置WebSocket的相关端点,如`...

Global site tag (gtag.js) - Google Analytics