简单学习 --> WebSocket

websocket

websocket 是应用层 协议, 基于传输层Tcp 协议 的协议 ;

这个协议可以实现服务器主动给客户端推送信息功能(本身Tcp就可以做到,但是HTTP不行)

websocket报文格式

websocket 和服务器建立连接的过程

首先 客户端 发送 HTTP请求 给服务器 , 请求里 包含了一些特殊header , (告诉 服务器 要不要和我升级成 websocket) ,

服务器 也会 返回响应给 客户端, (同意升级 ) , 这样客户端和服务器就建立了 websocket的 连接, 后续就使用 websocket 进行传输;

就 跟 HTTP没关系了 ;

websocket 的使用

在java有两种形式使用功能 websocket

  1. 使用Tomcat 提供的 websocket.api

  2. 使用Spring 提供的 websocket.api

使用websocket 例子
  1. 服务器代码(首先引入websocket依赖)

  2. 客户端代码(使用js)

服务器
  1. 创建 类 继承TextSocketHandler 类 , 重写主要的4个方法 (TextsocketHandler类,websocket支持文本和二进制,这里这个就代表支持文本的类)

  2. 把上面的类注册到Spring(交给Spring管理)

  3. 配置路由(关联路径对应上面的 创建的websocketHandler 类)

创建websocke类
返回响应
把创建的websocket 类的实例注册到Spring
配置路由
  1. 实现 接口

  2. 注册路径

  3. 有@EnableWebsocket

客户端

js的 websocket, 的 send () 发送方法 , 只能 发送 字符串 , 所有要发送json数据要把json转成json字符串

在处理前端和后端请求可以使用:

JSON.stringify(json数据) : 把json对象转成json字符串

JSON.parse () : 把json字符串转成json

前端使用 js 写 , 和服务器处理的流程一样: 1.连接成功 2. 收到消息 3. 连接异常 ,4. 连接关闭 ;

复制代码
<body>
    <input type="text" id="text">
    <button id="send-button">发送</button>
     <script>
            // 通过js ,创建Websocket对象 ;
            //  创建对象需要有路径 , 就是 websocket 传输消息的路径 , 对应服务器的路径, 就是发送信息给服务器 ;
            // ws : 代表的是 协议名称 , ws 就是websocket
            let websocket = new websocket('ws://127.0.0.1:8080/test') ; 
​
        //    给 websocket 创建几个 回调函数 ;
        websocket.onopen = function(){
            //  连接建立成功后, 自动调用 ;
            console.log("连接建立成功");
            
        }
​
        websocket.onmessage = function(e){
        //     收到消息后 ,调用
        //  这里的 e 参数 , 就是 收到的消息 ;
            console.log("收到消息"+e.data);
        }
​
        websocket.onerror = function(){
            // 链接发生异常时 ,调用
            console.log("连接发生异常");
            
        }
​
        websocket.onclose = function(){
            // 连接发生关闭后调用
            console.log("连接断开了");
            
        }
        
        // 给上面的 发送按钮,添加一个 发送点击事件, 把消息发送出去;
        let sendButton = document.querySelector("#send-button") ;
        let message = document.querySelector('#text');
        sendButton.onclick = function(){
            // 发送消息 ,前面已经有 websocket , websocket 已经有服务器的信息, 可以直接通过它向服务器发送数据 ;
            //  客户端就不需要会话的概念了 , 只需要知道服务器就行,服务器才需要管理会话 ;
            websocket.send(message.value) ;
        }
​
​
     </script>
</body>
服务器-客户端交互
相关推荐
swordbob2 小时前
缓存延迟双删的两种策略
java·缓存
凡人叶枫2 小时前
Effective C++ 条款08:别让异常逃离析构函数
java·linux·数据库·c++·嵌入式开发
云烟成雨TD2 小时前
Agent Scope Java 2.x 系列【4】模型层
java·人工智能·agent
chase。2 小时前
【学习笔记】Dexora:面向高自由度双臂灵巧操作的开源 VLA 系统
笔记·学习
風清掦2 小时前
【STM32学习笔记-15】FLASH 闪存(Claude)
笔记·stm32·单片机·嵌入式硬件·学习
新时代牛马2 小时前
内核调试方法
linux·学习
云烟成雨TD2 小时前
Agent Scope Java 2.x 系列【5】智能体抽象层
java·人工智能·agent
我想我不够好。2 小时前
贝利亚 扎克
学习
阿伟AI说2 小时前
Codex 桌面版接入国产模型系列二:Codex++
java·开源软件·ai编程·腾讯云ai代码助手
love_muming3 小时前
链表每日一练
java·开发语言·数据结构·链表·idea·每日一练