springboot 2整合websocket推送消息、数据流、解析pdf图片并压缩
yuyutoo 2025-01-21 22:37 4 浏览 0 评论
springboot 2.4.6整合websocket
gitee地址:https://gitee.com/wyait/spring-boot-websocket.git
spring-boot-websocket : springboot整合websocket实现简版聊天室、上传文件、推流文件到客户端、解析pdf文件为图片,并进行图片压缩
github地址:https://github.com/wyait/springboot-websocket.git
本文需要一定的java、springboot技术基础。
这里只是阐述说明,实际效果需要结合源码进行理解。
整合websocket实现推送数据(消息、图片)流
什么是webSocket?
它的最大特点就是,服务器可以主动向客户端推送信息,客户端也可以主动向服务器发送信息,是真正的双向平等对话,属于服务器推送技术的一种。
在 WebSocket API 中,浏览器和服务器只需要做一个握手的动作,
然后,浏览器和服务器之间就形成了一条快速通道。两者之间就直接可以数据互相传送。
websocket特点:
- 1.建立在 TCP 协议之上,服务器端的实现比较容易。
- 2.与 HTTP 协议有着良好的兼容性。默认端口也是80和443,并且握手阶段采用 HTTP 协议,因此握手时不容易屏蔽,能通过各种 HTTP 代理服务器。
- 3.数据格式比较轻量,性能开销小,通信高效。
- 4.可以发送文本,也可以发送二进制数据。
- 5.没有同源限制,客户端可以与任意服务器通信。
- 6.协议标识符是ws(如果加密,则为wss),服务器网址就是 URL。
相关api,todo
场景
前后端分离项目,业务员在后台PC操作的图片切换,前端客户端页面可以动态展示。考虑通过websocket建立通讯通道,实现服务器端主动推送文件流给前端,实现动态图片文件展示。
websocket适用场景:
- 聊天
- 多用户(协同)编辑
- 服务端推送数据流到客户端
- 音视频聊天 / 视频会议 / 在线教育:用WebSockets getUserMedia API和HTML5音视频元素是个不错的选择。WebRTC的出现顺理成章的成为刚才概括的组合体,它看起来很有希望,但其缺乏目前浏览器的支持。
相关技术
- springboot 2.4.6
- websocket
- jdk1.8
- fastjson 1.2.79 (注意:有版本兼容性问题)
demo测试访问地址
- 本地聊天室访问地址: http://127.0.0.1:8033/websocketDemo.html
- 通过websocket主动推流图片到前端,动态切换图片接口地址:http://127.0.0.1:8033/ppt/change/1/5
- pdf解析为图片访问地址:http://127.0.0.1:8033/pdf.html
动态切换图片,主动推送数据流接口示例
http://127.0.0.1:8033/ppt/change/{sid}/{fileName}
sid:不同用户(demo只是区分了1和其他),对应查看的图片内容不一样
fileName:分享图片的名称(注意,本地是加载指定路径下的图片文件,跑demo的时候,要提前准备好)
创建springboot项目并集成websocket
项目相关代码,详见源码,这里就不赘述。
WebSocketServer
我们需要实现它的三个方法:OnOpen,OnClose,OnMessage
他们都会自动调用,类似于事件触发,含义分别是,连接建立成功时调用的方法,连接关闭时调用的方法,最后一个是接收客户端发来的消息
其中OnMessage我们后面会使用多种实现,支持数据、二进制数据流。
使用websocket实现文件上传功能
我们仿造刚才的
WebSocketServer
在写一个websocket类
还是在web包下建立一个类,类名为
WebSocketUploadServer
可以将原来WebSocketServer的代码复制过来,然后稍微改造一下,其实我们实现文件上传也可以直接在原来WebSocketServer的代码里直接实现。
原本聊天室的情况下,一个房间里是可以有多个客户端连接的,但是文件上传我们是不允许的,假如有多个人在同一个房间,那么消息就会传到每个客户端,因为我们要做分块上传,所以这里控制每个房间只能有一个人。
我们把websocketDemo.html也复制一份,改名就叫
uploadFileDemo.html
我们原先的房间号是手动输入的,现在,我们保证每次都是不同的房间号所以,这次房间号就用随机数。
当然方法有很多种,我只是提供一种简单的实现方式,不同的业务场景当然也需要不同的实现方式。
后台的核心代码主要是接收字节流和json消息,我们将字符串消息格式化成了json消息。
1,接收字符串:public void onMessage(String message, Session session) {}
2,接收字节流:public void onMessage(byte[] message, Session session) {}
业务逻辑我们放在了service层进行处理
在websocketupload包下建立service包
然后建立SaveFileI接口,接口里有两个方法,一个是创建文件路径的,一个是将流数据写入文件。
我们在websocket服务里注入接口的时候要注意一点,因为spring是单例的,websocket在初始化的时候就实例化了spring的bean,但是当websocket创建一个新的连接的时候spring的bean会出现null的问题(static静态注入问题),也就是它只注入了一次。解决方案详见代码,或组合使用@PostConstruct注解解决。
最后返回的这个文件地址,项目中指定本地目录下。
websocket推送图片流到前端
1,聊天页面websocketDemo.html新增图片img标签,用于展示推送的图片显示。
2,service层新增websocket推送二进制数据流到前端,WebsocketServer.sendPic()。
3,后台新增动态切换图片接口PptImgController(service层调用websocket推送二进制数据流到前端方法)。
4,本地指定文件路径WebsocketServer.sendPic().filePath下,放置测试图片文件(命名要和接口3中的一致)。
详见代码。
新增上传PPT文件,每页生成单独的图片
//todo 图片超出制定大小,进行压缩处理。
方案一 使用pdfbox插件【推荐】
上传pdf文件,转为图片保存,并生成图片地址。
1,引入依赖:
<!-- springboot parent版本2.4.6 -->
<!-- pdfbox 用于将pdf转为字节码数组 -->
<dependency>
<groupId>org.apache.pdfbox</groupId>
<artifactId>pdfbox</artifactId>
<version>2.0.23</version>
</dependency>
<!-- Hutool工具类:用于将文件字节数据保存为图片,到指定目录 -->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.3.8</version>
</dependency>
2,接口入口PdfToImgController 请求示例:/pdf/to/image
3,pdf转图片工具类PdfToImageUtils
4,页面请求地址:http://127.0.0.1:8033/pdf.html
保存图片位置,PdfToImageUtils.IMG_PATH,demo路径为:D:\\data\\images\\pdf\\ (可自定义)
无中文乱码问题。
方案二 使用icepdf插件【不推荐】
详见源码:ImageUtils类,
遗留问题:在解析pdf时,应用服务所在的系统环境中,如果存在不支持的字体,就会出现中文乱码,需要额外在系统环境中安装字体。
其他方案
itextpdf插件
等比压缩图片功能
详见:PdfToImageUtils.compressPic()方法
相关推荐
- 全局和隐式 using 指令详解(全局命令)
-
1.什么是全局和隐式using?在.NET6及更高版本中,Microsoft引入了...
- 请停止微服务,做好单体的模块化才是王道:Spring Modulith介绍
-
1、介绍模块化单体是一种架构风格,代码是根据模块的概念构成的。对于许多组织而言,模块化单体可能是一个很好的选择。它有助于保持一定程度的独立性,这有助于我们在需要的时候轻松过渡到微服务架构。Spri...
- ASP.NET程序集引用之痛:版本冲突、依赖地狱等解析与实战
-
我是一位多年后端经验的工程师,其中前几年用ASP.NET...
- .NET AOT 详解(.net 6 aot)
-
简介AOT(Ahead-Of-TimeCompilation)是一种将代码直接编译为机器码的技术,与传统的...
- 一款基于Yii2开发的免费商城系统(一款基于yii2开发的免费商城系统是什么)
-
哈喽,我是老鱼,一名致力于在技术道路上的终身学习者、实践者、分享者!...
- asar归档解包(游戏arc文件解包)
-
要学习Electron逆向,首先要有一个Electron开发的程序的发布的包,这里就以其官方的electron-quick-start作为例子来进行一下逆向的过程。...
- 在PyCharm 中免费集成Amazon CodeWhisperer
-
CodeWhisperer是Amazon发布的一款免费的AI编程辅助小工具,可在你的集成开发环境(IDE)中生成实时单行或全函数代码建议,帮助你快速构建软件。简单来说,AmazonCodeWhi...
- 2014年最优秀JavaScript编辑器大盘点
-
1.WebstormWebStorm是一种轻量级的、功能强大的IDE,为Node.js复杂的客户端开发和服务器端开发提供完美的解决方案。WebStorm的智能代码编辑器支持JavaScript,...
- 基于springboot、tio、oauth2.0前端vuede 超轻量级聊天软件分享
-
项目简介:基于JS的超轻量级聊天软件。前端:vue、iview、electron实现的PC桌面版聊天程序,主要适用于私有云项目内部聊天,企业内部管理通讯等功能,主要通讯协议websocket。支持...
- JetBrains Toolbox推出全新产品订阅授权模式
-
捷克知名软件开发公司JetBrains最为人所熟知的产品是Java编程语言开发撰写时所用的集成开发环境IntelliJIDEA,相信很多开发者都有所了解。而近期自2015年11月2日起,JetBr...
- idea最新激活jetbrains-agent.jar包,亲测有效
-
这里分享一个2019.3.3版本的jetbrains-agent.jar,亲测有效,在网上找了很多都不能使用,终于找到一个可以使用的了,这里分享一下具体激活步骤,此方法适用于Jebrains家所有产品...
- CountDownTimer的理解(countdowntomars)
-
CountDownTimer是android开发常用的计时类,按照注释中的说明使用方法如下:kotlin:object:CountDownTimer(30000,1000){...
- 反射为什么性能会很慢?(反射时为什么会越来越长)
-
1.背景前段时间维护一个5、6年前的项目,项目总是在某些功能使用上不尽人意,性能上总是差一些,仔细过了一下代码发现使用了不少封装好的工具类,工具类里面用了好多的反射,反射会影响到执行效率吗?盲猜了一...
- btrace 开源!基于 Systrace 高性能 Trace 工具
-
介绍btrace(又名RheaTrace)是抖音基础技术团队自研的一款高性能AndroidTrace工具,它基于Systrace实现,并针对Systrace不足之处加以改进,核心改进...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- .NET 奇葩问题调试经历之3——使用了grpc通讯类库后,内存一直增长......
- 全局和隐式 using 指令详解(全局命令)
- 请停止微服务,做好单体的模块化才是王道:Spring Modulith介绍
- ASP.NET程序集引用之痛:版本冲突、依赖地狱等解析与实战
- .NET AOT 详解(.net 6 aot)
- 一款基于Yii2开发的免费商城系统(一款基于yii2开发的免费商城系统是什么)
- asar归档解包(游戏arc文件解包)
- 在PyCharm 中免费集成Amazon CodeWhisperer
- 2014年最优秀JavaScript编辑器大盘点
- 基于springboot、tio、oauth2.0前端vuede 超轻量级聊天软件分享
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)