全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

详解在Spring Boot框架下使用WebSocket实现消息推送

spring Boot的学习持续进行中。前面两篇博客我们介绍了如何使用Spring Boot容器搭建Web项目以及怎样为我们的Project添加HTTPS的支持,在这两篇文章的基础上,我们今天来看看如何在Spring Boot中使用WebSocket。

什么是WebSocket

WebSocket为浏览器和服务器之间提供了双工异步通信功能,也就是说我们可以利用浏览器给服务器发送消息,服务器也可以给浏览器发送消息,目前主流浏览器的主流版本对WebSocket的支持都算是比较好的,但是在实际开发中使用WebSocket工作量会略大,而且增加了浏览器的兼容问题,这种时候我们更多的是使用WebSocket的一个子协议stomp,利用它来快速实现我们的功能。OK,关于WebSocket我这里就不再多说,我们主要看如何使用。

Project创建

使用WebSocket需要我们先创建一个Project,这个Project的创建方式和我们前文(初识Spring Boot框架)说的一样,不同的是在选择依赖的时候选择Thymeleaf和WebSocket依赖,如下图:

配置WebSocket

Project创建成功之后,我们先来配置WebSocket,创建如下类:

@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig extends AbstractWebSocketMessageBrokerConfigurer {
  @Override
  public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry) {
    stompEndpointRegistry.addEndpoint("/endpointSang").withSockJS();
  }

  @Override
  public void configureMessageBroker(MessageBrokerRegistry registry) {
    registry.enableSimpleBroker("/topic");
  }
}

关于这个类我说如下几点:

1@EnableWebSocketMessageBroker注解表示开启使用STOMP协议来传输基于代理的消息,Broker就是代理的意思。

2.registerStompEndpoints方法表示注册STOMP协议的节点,并指定映射的URL。

3.stompEndpointRegistry.addEndpoint("/endpointSang").withSockJS();这一行代码用来注册STOMP协议节点,同时指定使用SockJS协议。

4.configureMessageBroker方法用来配置消息代理,由于我们是实现推送功能,这里的消息代理是/topic

创建浏览器发送消息的接收类

浏览器发送来的消息用这个类来接收:

public class RequestMessage {

  private String name;

  public String getName() {
    return name;
  }
}

创建响应消息类

服务器返回给浏览器的消息由这个类来承载:

public class ResponseMessage {
  private String responseMessage;

  public ResponseMessage(String responseMessage) {
    this.responseMessage = responseMessage;
  }

  public String getResponseMessage() {
    return responseMessage;
  }
}

创建控制器

@Controller
public class WsController {
  @MessageMapping("/welcome")
  @SendTo("/topic/getResponse")
  public ResponseMessage say(RequestMessage message) {
    System.out.println(message.getName());
    return new ResponseMessage("welcome," + message.getName() + " !");
  }
}

关于这个控制器,首先@Controller注解不必多言,say方法上添加的@MessageMapping注解和我们之前使用的@RequestMapping类似。@SendTo注解表示当服务器有消息需要推送的时候,会对订阅了@SendTo中路径的浏览器发送消息。

添加脚本

我们这个案例需要三个js脚本文件,分别是STOMP协议的客户端脚本stomp.js、SockJS的客户端脚本sock.js以及jQuery,这三个js文件拷贝到src/main/resources/static/js目录下。OK,这三个js文件我已经为小伙伴们准备好了,可以直接在文末下载案例,案例中有,也可以自行下载这三个js文件。

演示页面

在写这个HTML页面之前,我想先说我们要实现的效果是什么样子的。当我的Project启动之后,在浏览器访问消息发送页面,在该页面发送一条消息,当服务端收到这条消息之后给所有的连接上了服务器的浏览器都发送一条消息。OK,我们在src/main/resources/templates目录下新建一个ws.html页面,内容如下:

<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
  <meta charset="UTF-8"/>
  <title>广播式WebSocket</title>
  <script th:src="@{js/sockjs.min.js}"></script>
  <script th:src="@{js/stomp.js}"></script>
  <script th:src="@{js/jquery-3.1.1.js}"></script>
</head>
<body onload="disconnect()">
<noscript><h2 style="color: #e80b0a;">Sorry,浏览器不支持WebSocket</h2></noscript>
<div>
  <div>
    <button id="connect" onclick="connect();">连接</button>
    <button id="disconnect" disabled="disabled" onclick="disconnect();">断开连接</button>
  </div>

  <div id="conversationDiv">
    <label>输入你的名字</label><input type="text" id="name"/>
    <button id="sendName" onclick="sendName();">发送</button>
    <p id="response"></p>
  </div>
</div>
<script type="text/javascript">
  var stompClient = null;
  function setConnected(connected) {
    document.getElementById("connect").disabled = connected;
    document.getElementById("disconnect").disabled = !connected;
    document.getElementById("conversationDiv").style.visibility = connected ? 'visible' : 'hidden';
//    $("#connect").disabled = connected;
//    $("#disconnect").disabled = !connected;
    $("#response").html();
  }
  function connect() {
    var socket = new SockJS('/endpointSang');
    stompClient = Stomp.over(socket);
    stompClient.connect({}, function (frame) {
      setConnected(true);
      console.log('Connected:' + frame);
      stompClient.subscribe('/topic/getResponse', function (response) {
        showResponse(JSON.parse(response.body).responseMessage);
      })
    });
  }
  function disconnect() {
    if (stompClient != null) {
      stompClient.disconnect();
    }
    setConnected(false);
    console.log('Disconnected');
  }
  function sendName() {
    var name = $('#name').val();
    console.log('name:' + name);
    stompClient.send("/welcome", {}, JSON.stringify({'name': name}));
  }
  function showResponse(message) {
    $("#response").html(message);
  }
</script>
</body>
</html>

这里虽然代码略多,但是仔细分析一下却也很简单。首先js文件引入的那一部分我就不再多说,这里如果又不理解的可以参考使用Spring Boot开发Web项目。然后我们的页面上先有两个按钮,一个是连接,一个是断开连接,两个按钮分别对应不同的点击事件,在这两个按钮下方有一个输入框,就是我们要发送的内容,然后还有一个发送按钮,发送按钮对应了一个发送消息的点击事件。这是整个页面的元素,很简单,我们这里重点来看一下js逻辑代码。

connect方法是当我点击连接按钮的时候执行的,var socket = new SockJS('/endpointSang');表示连接的SockJS的endpoint名称为/endpointSang,stompClient = Stomp.over(socket);表示使用STOMP来创建WebSocket客户端。然后调用stompClient中的connect方法来连接服务端,连接成功之后调用setConnected方法,该隐藏的隐藏,该显示的显示。然后再通过调用stompClient中的subscribe方法来订阅/topic/getResponse发送来的消息,也就是我们在Controller中的say方法上添加的@SendTo注解的参数。stompClient中的send方法表示发送一条消息到服务端,其他的都是常规的js用法我就不再赘述。

配置viewController

接下来就是要为ws.html提供路径映射:

@Configuration
public class WebMvcConfig extends WebMvcConfigurerAdapter {
  @Override
  public void addViewControllers(ViewControllerRegistry registry) {
    registry.addViewController("/ws").setViewName("/ws");
  }
}

OK,做完这一切之后我们就可以运行项目了,我同时打开多个浏览器,然后在其中一个上发送消息,我们来看看结果:

我在最上面的浏览器上发送消息,其他两个浏览器都能收到我的消息。

OK ,以上就是我们在Spring Boot框架下使用WebSocket实现消息推送的全过程。

本案例下载地址:demo

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# springboot  # websocket  # spring  # websocket推送  # 消息推送  # php实现websocket实时消息推送  # Android中使用WebSocket实现群聊和消息推送功能(不使用WebView)  # SpringBoot+WebSocket+Netty实现消息推送的示例代码  # SpringMVC整合websocket实现消息推送及触发功能  # websocket实现Vue 3和Node.js之间的实时消息推送  # 发送消息  # 这三个  # 我就  # 服务端  # 在这  # 客户端  # 很简单  # 来看看  # 双工  # 多说  # 方法来  # 如何使用  # 两篇  # 的是  # 都是  # 这是  # 我想  # 是在  # 我在  # 我说 


相关文章: 湖北网站制作公司有哪些,湖北清能集团官网?  如何在景安服务器上快速搭建个人网站?  网站制作报价单模板图片,小松挖机官方网站报价?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  网站微信制作软件,如何制作微信链接?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  较简单的网站制作软件有哪些,手机版网页制作用什么软件?  建站之星官网登录失败?如何快速解决?  无锡营销型网站制作公司,无锡网选车牌流程?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  官网建站费用明细查询_企业建站套餐价格及收费标准指南  建站之星后台搭建步骤解析:模板选择与产品管理实操指南  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  活动邀请函制作网站有哪些,活动邀请函文案?  已有域名和空间,如何快速搭建网站?  文字头像制作网站推荐软件,醒图能自动配文字吗?  如何制作网站标识牌,动态网站如何制作(教程)?  深圳网站制作案例,网页的相关名词有哪些?  建站之星后台密码遗忘如何找回?  学校为何禁止电信移动建设网站?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  网站建设制作、微信公众号,公明人民医院怎么在网上预约?  如何打造高效商业网站?建站目的决定转化率  建站主机助手选型指南:2025年热门推荐与高效部署技巧  建站之星在线版空间:自助建站+智能模板一键生成方案  如何在Golang中引入测试模块_Golang测试包导入与使用实践  建站之星如何实现网站加密操作?  如何通过老薛主机一键快速建站?  定制建站价位费用解析与套餐推荐全攻略  可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?  网站制作公司排行榜,抖音怎样做个人官方网站  高防服务器:AI智能防御DDoS攻击与数据安全保障  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  制作网站的软件免费下载,免费制作app哪个平台好?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  如何选择适合PHP云建站的开源框架?  微信h5制作网站有哪些,免费微信H5页面制作工具?  惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?  济南企业网站制作公司,济南社保单位网上缴费步骤?  如何基于PHP生成高效IDC网络公司建站源码?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何用景安虚拟主机手机版绑定域名建站?  企业微网站怎么做,公司网站和公众号有什么区别?  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  孙琪峥织梦建站教程如何优化数据库安全?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何高效搭建专业期货交易平台网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。