netty启用websocket的压缩机制

netty启用websocket的压缩机制

package com.aerotop.connector.websocket.base;import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelPipeline;
import io.netty.channel.socket.SocketChannel;
import io.netty.handler.codec.compression.JZlibDecoder;
import io.netty.handler.codec.compression.JZlibEncoder;
import io.netty.handler.codec.http.HttpObjectAggregator;
import io.netty.handler.codec.http.HttpServerCodec;
import io.netty.handler.codec.http.websocketx.WebSocketServerProtocolHandler;
import io.netty.handler.codec.http.websocketx.extensions.compression.WebSocketServerCompressionHandler;
import io.netty.handler.stream.ChunkedWriteHandler;
import io.netty.handler.timeout.IdleStateHandler;/*** @author xhh*/
public class WebSocketServerInitialzer extends ChannelInitializer<SocketChannel> {@Overrideprotected void initChannel(SocketChannel socketChannel) throws Exception {ChannelPipeline pipeline = socketChannel.pipeline();//websocket 基于http协议,所以要有http编解码器pipeline.addLast(new HttpServerCodec());//对写大数据流的支持pipeline.addLast(new ChunkedWriteHandler());//对httpMessage进行聚合,聚合成fullHttpRequest或fullHttpResponespipeline.addLast(new HttpObjectAggregator(1024 * 64));//支持websocket,并启用压缩,设置压缩子协议pipeline.addLast(new WebSocketServerProtocolHandler("/websocket", "permessage-deflate", true));// 添加压缩处理器pipeline.addLast(new WebSocketServerCompressionHandler());//自定义的handlerpipeline.addLast(new NettyWebSocketHandler());}
}

前端vue,websocket启用压缩

<template><div id="app-1"><!-- 输入框绑定message数据 --><input type="text" v-model="message" placeholder="输入消息"@keyup.enter="sendMessage"><!-- 发送按钮 --><button @click="sendMessage">发送</button><!-- 消息展示区域 --><div id="output"><!-- 遍历messages数组 --><p v-for="(msg, index) in messages" :key="index">{{ msg }}</p></div></div>
</template><script>export default {data() {return {message: '',       // 绑定输入框内容messages: [],      // 存储所有消息记录socket: null       // WebSocket实例};},mounted() {// 组件挂载后初始化WebSocketthis.initWebSocket()},methods: {// 初始化WebSocket连接initWebSocket() {// 创建带压缩协商的WebSocket连接this.socket = new WebSocket('ws://127.0.0.1:8002/websocket', ['permessage-deflate'])// 连接成功回调this.socket.onopen = (event) => {this.log(`连接已建立,压缩支持:${this.socket.extensions}`)}// 接收消息回调this.socket.onmessage = (event) => {this.log(`收到消息: ${event.data}`)}// 错误处理this.socket.onerror = (error) => {debuggerthis.log('连接错误: ' + error)}// 连接关闭处理this.socket.onclose = (event) => {this.log('连接已关闭')}},// 发送消息方法sendMessage() {if (!this.message.trim()) return  // 空消息过滤if (this.socket.readyState === WebSocket.OPEN) {this.socket.send(this.message)this.log(`已发送: ${this.message}`)this.message = ''  // 清空输入框} else {this.log('连接未就绪')}},// 记录日志方法log(text) {this.messages.push(text)  // 自动触发视图更新// 自动滚动到底部(可选)const outputDiv = document.getElementById('output')if (outputDiv) {outputDiv.scrollTop = outputDiv.scrollHeight}}},beforeDestroy() {// 组件销毁前关闭连接if (this.socket) {this.socket.close()}}};
</script><style scoped>
/* 修改后的样式 */
#app {max-width: 600px;margin: 20px auto;padding: 20px;background: #2d3439;  /* 新增背景色 */
}#output {margin-top: 20px;height: 900px;overflow-y: auto;border: 1px solid #3d4a52;  /* 调整边框颜色 */padding: 10px;background: #1e2327;  /* 深色背景 */border-radius: 8px;   /* 添加圆角 */
}p {margin: 5px 0;padding: 8px 12px;color: #ffffff;       /* 白色文字 */background: #2d3439;  /* 消息背景 */border-radius: 4px;   /* 圆角效果 */border-bottom: 1px solid #3d4a52; /* 调整分割线 */
}/* 滚动条样式 */
#output::-webkit-scrollbar {width: 8px;
}#output::-webkit-scrollbar-track {background: #1e2327;
}#output::-webkit-scrollbar-thumb {background: #3d4a52;border-radius: 4px;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/75594.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

可能存在特殊情况,比如控制台显示有延迟、缓冲问题等影响了显示顺序。

从控制台输出看&#xff0c;正常逻辑应是先执行 System.out.println(" 未处理异常演示 "); 输出对应文本&#xff0c;再因 arr 为 null 访问 length 触发 NullPointerException 输出异常信息。可能存在特殊情况&#xff0c;比如控制台显示有延迟、缓冲问题等影响…

第一节:React 基础篇-React虚拟DOM原理及Diff算法优化策略

必考点&#xff1a;虚拟DOM树对比&#xff08;同级比较、Key的作用、组件类型判断&#xff09; 延伸&#xff1a;React 18中并发更新对Diff算法的影响 React虚拟DOM原理及Diff算法优化策略 虚拟DOM核心原理 概念&#xff1a; • 虚拟DOM&#xff08;Virtual DOM&#xff09;…

Java spring mybatis面试题(200道),八股文

Java面试题 通过网盘分享的文件&#xff1a;面试题等2个文件 链接: https://pan.baidu.com/s/1Xw0PzkfAmL8uesYBvrW2-A?pwdpebt 提取码: pebt mybatis相关 1、 什么是Mybatis&#xff1f; … 2 2、 Mybaits 的优点&#xff1a; … 2 3、 MyBatis 框架的缺点&#xff1a; ……

windows使用Python调用7-Zip【按大小分组】压缩文件夹中所有文件

使用Python调用7-Zip【按大小分组】压缩文件夹中所有文件 问题描述&#xff1a;方法前提条件任务完整代码示例代码如何工作&#xff1f; 问题描述&#xff1a; 我现在想把文件夹下的所有内容上传到网盘&#xff0c;但是这个文件夹下的素材内容很多&#xff0c;使用分卷压缩的话…

《Python星球日记》第26天:Matplotlib 可视化

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 订阅专栏&#xff1a;《Python星球日记》 目录 一、Matplotlib 简介1. 什么是 Matplo…

第1章 对大型语言模型的介绍

人类正处在一个关键转折点。自2012年起&#xff0c;基于深度神经网络的人工智能系统研发进入快速通道&#xff0c;将这一技术推向了新高度&#xff1a;至2019年底&#xff0c;首个能够撰写与人类文章真假难辨的软件系统问世&#xff0c;这个名为GPT-2&#xff08;生成型预训练变…

dcsdsds

我将为您在页面顶部添加欢迎内容&#xff0c;同时保持整体风格的一致性。以下是修改后的代码&#xff0c;主要修改了模板部分和对应的样式&#xff1a; vue 复制 <template><div class"main-wrapper"><!-- 新增欢迎部分 --><div class"…

学习MySQL的第八天

海到无边天作岸 山登绝顶我为峰 一、数据库的创建、修改与删除 1.1 引言 在经过前面七天对于MySQL基本知识的学习之后&#xff0c;现在我们从基本的语句命令开始进入综合性的语句的编写来实现特定的需求&#xff0c;从这里开始需要我们有一个宏观的思想&…

Linux-内核驱动-中断-key

DEV_NAME&#xff1a;设备名称。 wg&#xff1a;等待队列头&#xff0c;用于同步。 condition&#xff1a;条件变量&#xff0c;用于等待和唤醒。 中断处理函数 irq_handler&#xff1a;处理中断请求&#xff0c;设置条件变量并唤醒等待队列中的进程。 文件操作函数 open…

asm汇编源代码之按键处理相关函数

提供5个子程序: 1. 发送按键 sendkey 2. 检测是否有按键 testkey 3. 读取按键 getkey 4. 判断键盘缓冲区是否为空 bufempty 5. 判断键盘缓冲区是否已满 buffull 具体功能及参数描述如下 sendkey proc  far ; axcharcode testkey proc  far ; out: ;   zf1 buff empt…

Java Collections 类中常用方法使用

一、Collections类 java.util.Collections 类是 Java 集合框架中的一个工具类&#xff0c;提供了一系列静态方法来操作和处理各种类型的集合。这些方法简化了对集合进行排序、查找、同步控制、创建只读集合等常见操作的过程。 二、常用方法 方法类别‌‌方法签名‌‌功能‌‌需…

Linux网络编程——数据链路层详解,以太网、MAC地址、MTU、ARP、DNS、NAT、代理服务器......

目录 一、前言 二、以太网 二、以太网帧格式 三、 MAC地址 四、MTU 1、数据链路层的数据分片 2、MTU对UDP协议的影响 3、MTU对TCP协议的影响 五、ARP协议 1、什么是ARP 2、ARP的作用 3、ARP协议的工作流程 4、ARP缓存表 5、ARP请求报文 6、中间人 六、DNS&…

轻量级开源文件共享系统PicoShare本地部署并实现公网环境文件共享

&#xfeff;## 前言 本篇文章介绍&#xff0c;如何在 Linux 系统本地部署轻量级文件共享系统 PicoShare&#xff0c;并结合 Cpolar 内网穿透实现公网环境远程传输文件至本地局域网内文件共享系统。 PicoShare 是一个由 Go 开发的轻量级开源共享文件系统&#xff0c;它没有文…

基于查表法的 CRC8 / CRC16 / CRC32校验解析

在嵌入式开发中&#xff0c;CRC&#xff08;Cyclic Redundancy Check&#xff09;循环冗余校验算法广泛应用于通信数据校验、Flash 数据完整性检测、Bootloader 升级验证等场景。本文将深入剖析一套完整的 CRC8、CRC16 和 CRC32 实现&#xff0c;并通过查表法&#xff08;Table…

二战蓝桥杯所感

&#x1f334; 前言 今天是2025年4月12日&#xff0c;第十六届蓝桥杯结束&#xff0c;作为二战的老手&#xff0c;心中还是颇有不甘的。一方面&#xff0c;今年的题目比去年简单很多&#xff0c;另一方面我感觉并没有把能拿的分都拿到手&#xff0c;这是我觉得最遗憾的地方。不…

基于ueditor编辑器的功能开发之给编辑器图片增加水印功能

用户需求&#xff0c;双击编辑器中的图片的时候&#xff0c;出现弹框&#xff0c;用户可以选择水印缩放倍数、距离以及水印所放置的方位&#xff08;当然有很多水印插件&#xff0c;位置大小透明度用户都能够自定义&#xff0c;但是用户需求如此&#xff0c;就自己写了&#xf…

算法题(123):回文日期

审题&#xff1a; 本题需要我们判断以八位数确定的日期范围中是否存在回文数 思路&#xff1a; 方法一&#xff1a;枚举法 1.确定枚举对象&#xff1a; 对象1&#xff1a;八位数日期&#xff0c;所需枚举次数&#xff1a;10^8 对象2&#xff1a;年&#xff0c;所需枚举次数&…

数据库表的操作

一、数据库的搭建 如上篇文章 二、基础了解 show命令支持模糊匹配 show databases、show tables、 show databases like “” “%”、“_”通配符字符串 三、MySQL数据库表的操作 关系型数据库都是遵循SQL语法进行数据查询和管理的 3.1 SQL介绍 3.1.1 SQL的功能 结构化查询语…

在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法

在 Lua 中实现 JSON 与 Table 的相互转换是常见的数据序列化需求。以下是详细的实现方案、性能优化技巧及进阶用法&#xff1a; 在 Lua 中实现 JSON 与 Table 的相互转换的详细使用方法-目录 一、常用 JSON 库对比二、基础转换实现1. 使用 lua-cjson&#xff08;高性能 C 库&am…

dbVisitor 规则怎么用?

在数据库操作中&#xff0c;dbVisitor 是一个功能强大的工具&#xff0c;其规则的使用大大简化了 SQL 语句的编写过程。下面将详细介绍 dbVisitor 规则的使用方法并附上具体例子。 一、规则的基本调用 在 dbVisitor 中&#xff0c;SQL 语句可以通过 {...} 的形式来调用规则&a…