首页 > 其他分享 >spring boot(学习笔记第十五课)

spring boot(学习笔记第十五课)

时间:2024-07-30 23:00:18浏览次数:16  
标签:function web socket spring boot server stompClient 第十五

spring boot(学习笔记第十五课)

  • Spring boot的websocket(广播)

学习内容:

  • Spring boot的websocket(广播)

1. Spring boot的websocket(广播)

  1. 回顾下web server的进化
    在这里插入图片描述
      1. 第一代Web程序,使用整体页面刷新技术,对整个页面进行刷新。
        缺点:明明不需要的页面部分,也要全部刷新,对于网络带宽占用较大,而且效率很低。
      1. 第二代Web程序,使用ajax刷新技术,对页面进行局部刷新。
        优点:仅仅需要刷新页面的部分,向服务器发出请求,并将应答数据进行web页面局部刷新。
        缺点:只能浏览器主动pullweb server。不能实时realtime检测到web server的数据变化。
      1. 第二代Web程序,使用ajax刷新技术,对web server进行长轮训long polling
      1. 第三代Web程序,使用web socket刷新技术,让web clientweb server进行实时数据交互。在这里插入图片描述
  2. 开始练习spring boot上的web socket
    • spring boot添加必要的依赖(服务器端配置)
       <dependency>
                  <groupId>org.springframework.boot</groupId>
                  <artifactId>spring-boot-starter-websocket</artifactId>
              </dependency>
              <dependency>
                  <groupId>org.webjars</groupId>
                  <artifactId>webjars-locator-core</artifactId>
              </dependency>
              <dependency>
                  <groupId>org.webjars</groupId>
                  <artifactId>sockjs-client</artifactId>
                  <version>1.1.2</version>
              </dependency>
              <dependency>
                  <groupId>org.webjars</groupId>
                  <artifactId>stomp-websocket</artifactId>
                  <version>2.3.3</version>
              </dependency>
              <dependency>
                  <groupId>org.webjars</groupId>
                  <artifactId>jquery</artifactId>
                  <version>3.3.1</version>
              </dependency>
      
    • 进行endPointmessageBroker以及destinationPrefixes初始化配置(服务器端配置)
      @Configuration
      @EnableWebSocketMessageBroker
      public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {
          @Override
          public void configureMessageBroker(MessageBrokerRegistry messageBrokerRegistry) {
              messageBrokerRegistry.enableSimpleBroker("/topic");
              messageBrokerRegistry.setApplicationDestinationPrefixes("/app");
          }
          @Override
          public void registerStompEndpoints(StompEndpointRegistry stompEndpointRegistry){
              stompEndpointRegistry.addEndpoint("/chat").withSockJS();
          }
      }
      
      • addEndPoint
        web socketserverclient交互的端点。
      • setApplicationDestinationPrefixes
        web socket clientweb server发起请求的url
      • enableSimpleBroker
        web serverweb socket client发起请求的messageBroker
    • 配置controller(服务器端配置)
      @Controller
      public class WebSocketController {
          @MessageMapping("hello")
          @SendTo("/topic/greetings")
          public Message greeting(Message message) throws Exception {
              return message;
          }
      
      • Message message是从web socket client传递来的参数
      • @SendTo("/topic/greetings")是利用topic这个messageBroker讲消息在转发到web socket client
    • 配置客户端静态页面/static/chat.html
      <!DOCTYPE html>
      <html lang="en">
      <head>
          <meta charset="UTF-8">
          <title>聊天</title>
          <script src="/webjars/jquery/jquery.min.js"></script>
          <script src="/webjars/sockjs-client/sockjs.min.js"></script>
          <script src="/webjars/stomp-websocket/stomp.min.js"></script>
          <script src="/app.js"></script>
      </head>
      <body>
      <div>
          <label for="name">请输入用户名:</label>
          <input type="text" id="name" placeholder="用户名">
      </div>
      <div>
          <button id="connect" type="button">连接</button>
          <button id="disconnect" type="button" disabled="disabled">断开</button>
      </div>
      <div id="chat" style="display:none;">
          <div>
              <label for="content">请输入聊天内容:</label>
              <input type="text" id="content" placeholder="聊天内容">
          </div>
          <button id="send" type="button">发送</button>
          <div id="greetings">
              <div id="conversation" style="display:none">群聊进行中</div>
          </div>
      </div>
      </body>
      </html>
      
      在这里插入图片描述
    • 配置客户端的javascript /static/app.js
      • web socket的连接处理

        function connect(){
            if(!$("#name").val()){
                return;
            }
            var socket = new SockJS('/chat'); //连接endPoint
            stompClient = Stomp.over(socket);
            stompClient.connect({},function (frame){
                setConnected(true); //渲染控件
                stompClient.subscribe('/topic/greetings',function(greeting){ //注册web server报文接收的callback
                    showGreeting(JSON.parse(greeting.body));
                });
            });
        }
        
      • 点击发送的处理函数

        function sendName(){
            stompClient.send("/app/hello",{},
            JSON.stringify({'name':$("#name").val(),'content':$("#content").val()}));
        }
        
      • 页面的初始化函数

        $(function(){
            $("#connect").click(function(){connect();});
            $("#discontent").click(function(){disconnect()});
            $("#send").click(function(){sendName()});
        });
        
      • /static/app.js的全体

        var stompClient = null;
        function setConnected(connected){
            $("#connect").prop("disabled",connected);
            $("#disconnect").prop("disabled",!connected);
            if(connected){
                $("#conversation").show();
                $("#chat").show();
            }else{
                $("#conversation").hide();
                $("#chat").hide();
            }
            $("#greetings").html("");
        }
        function connect(){
            if(!$("#name").val()){
                return;
            }
            var socket = new SockJS('/chat');
            stompClient = Stomp.over(socket);
            stompClient.connect({},function (frame){
                setConnected(true);
                stompClient.subscribe('/topic/greetings',function(greeting){
                    showGreeting(JSON.parse(greeting.body));
                });
            });
        }
        function disconnect(){
            if(stompClient != null){
                stompClient.disconnect();
            }
            setConnected(false);
        }
        function sendName(){
            stompClient.send("/app/hello",{},
            JSON.stringify({'name':$("#name").val(),'content':$("#content").val()}));
        }
        function showGreeting(message){
            $("#greetings").append("<div>" + message.name +
            ":" + message.content + "</div>");
        }
        $(function(){
            $("#connect").click(function(){connect();});
            $("#discontent").click(function(){disconnect()});
            $("#send").click(function(){sendName()});
        });
        
  3. 测试spring boot上的web socket
    在两个浏览器上测试,输入名字,连接之后开始聊天。
    在这里插入图片描述

标签:function,web,socket,spring,boot,server,stompClient,第十五
From: https://blog.csdn.net/sealaugh1980/article/details/140621379

相关文章

  • Springboot3集成knife4j,swagger实现在线接口文档
    什么是knife4jknife4j是一个集Swagger2和OpenAPI3为一体的增强解决方案,帮助开发者快速聚合使用OpenAPI规范,快速生成API文档,并且提供一些额外的功能,比如:API文档生成:可以根据Controller和方法上的注解自动生成Markdown格式的API文档在线访问API:可以在knife4j的页面直接访问......
  • 基于springboot学生毕业离校系统lw(毕设+实现+源码+数据库)
    摘 要一年一度的毕业季的到来,方方面面都普及使得学生毕业离校系统的开发成为必需。学生毕业离校系统主要是借助计算机,通过对学生、教师、离校信息、费用结算、LW审核等信息进行管理。为减少管理员的工作,同时也方便广大学生对个人所需毕业离校的及时查询以及管理。学生毕......
  • 基于springboot音乐网站与分享平台(毕设+实现+源码+数据库)
                           摘要本LW主要论述了如何使用JAVA语言开发一个音乐网站与分享平台,本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述音乐网站与分享平台......
  • 记录些Spring+题集(32)
    10Wqps评论中台架构评论系统的业务分析在B站,UP主每天都会发布海量的视频、动态、专栏等内容,随之而来的是弹幕和评论区的各种讨论。播放器中直接滚动播放的弹幕,如同调味剂,重在提升视频观看体验;而点进评论区,相对而言评论文本更长,内容的观点、形式都更丰富,更像是饭后甜点。随着......
  • 用idea实现第一个springBoot
    hello@Controller@RequestMapping("/hello")publicclassHelloController{@GetMapping("/hello")@ResponseBodypublicStringhello(){return"hello";}} 更改端口号#更改端口号server.port=8081banner.tx......
  • spring源码 循环依赖
    spring框架两大核心:IOC和AOPIOC(InverseofControl)控制反转将对象的创建权交给Spring容器去创建,利用了工厂模式将对象交给容器管理,只需要在spring配置文件中配置相应的bean,以及设置相关的属性,让spring容器来生成类的实例对象以及管理对象。不需要我们手动new去创建对象,大......
  • 网络安全靶场系列(臃肿版):PbootCMS(V3.2.5)遇到的坑(您的服务器环境不支持gd扩展,将无法使
    PbootCMS(V3.2.5)遇到的坑(您的服务器环境不支持gd扩展,将无法使用验证码!)前言dockerphpgd扩展,docker安装php扩展gd库一、安装nginx、php、mysql镜像二、运行、停止、删除容器三、安装php扩展gd库四、扩展知识1、docker-php-source2、docker-php-ext-enable......
  • Spring AOP概念及原理
    SpringAOP(面向切面编程)以下内容由ChatGPT生成AOP(Aspect-OrientedProgramming,面向切面编程)是一种编程范式,旨在通过分离关注点来提高程序的模块化。SpringAOP主要用于横切关注点(如日志记录、安全、事务管理等)的实现。在Spring中,AOP的主要功能是为Bean增强功能,如添加额外......
  • springboot+vue基于微服务架构的设备管理系统【程序+论文+开题】-计算机毕业设计
    系统程序文件列表开题报告内容研究背景随着企业规模的不断扩大与信息化程度的日益加深,设备管理成为企业运营中不可或缺的一环。传统集中式架构的设备管理系统在面对大规模数据处理、高并发访问及系统扩展性等方面显得力不从心。微服务架构以其高度的模块化、灵活的服务部署......
  • 基于SpringBoot+Vue的电影院订票信息管理系统的详细设计和实现(源码+lw+部署文档+讲解
    文章目录前言详细视频演示项目运行截图技术框架后端采用SpringBoot框架前端框架Vue可行性分析系统测试系统测试的目的系统功能测试数据库表设计代码参考数据库脚本为什么选择我?获取源码前言......