博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
史上最简单的spring-boot集成websocket的实现方式
阅读量:1986 次
发布时间:2019-04-27

本文共 4089 字,大约阅读时间需要 13 分钟。

在应用程序中你只需要几行代码就可以快速的构建websocket服务

简介

在应用程序中你只需要几行代码就可以快速的构建websocket服务,对的这个就是我编写websocket-spring-boot-starter的初衷,主要是写传统的websocket的实现方式感觉每次写起来都好麻烦,又找不到一个好的websocketspring-boot集成的starter,那这样就自己写一个来用,大家在使用中遇到的BUG或者需求欢迎大家到上提issue。

要求

  • jdk版本为1.8或1.8+
  • spring-boot版本为2.0.1.RELEASE+
  • netty版本为4.1.42.Final

example例子

快速开始

1、添加依赖:

com.github.lazyboyl
websocket-spring-boot-starter
1.0.3.RELEASE

2、添加注解

在spring boot的启动类上加上@EnableWebSocketServer注解,并在该注解上设置好需要扫描的路径。

@SpringBootApplication@EnableWebSocketServer(webSocketScanPackage = {
"com.vue.demo.vue"})public class VueDemoApplication {
public static void main(String[] args) {
SpringApplication.run(VueDemoApplication.class, args); }}

3、编写第一个后端响应请求

你可以像写springMvc一样写websocket,完全不用像以前一样要做各种的配置和处理。

/** * @author linzf * @since 2020/7/15 * 类描述: 第一个请求类 */@WebSocketController@WebSocketRequestMapping("/user/")public class UserController {
/** * 这个userService就是我们平时在spring里面写的service */ @Autowired private UserService userService; /** * 功能描述: 模拟字段请求的方式来实现根据用户ID来获取用户数据 * * @param userId 用户的流水ID * @return */ @WebSocketRequestMapping("getUserVoByUserId") public UserVo getUserVoByUserId(String userId) {
return userService.getUserVoByUserId(userId); }}

4、编写第一个拦截器

只需要实现WebsocketSecurity接口即可,level方法主要用于界定这个过滤器的执行的顺序,数字越大则级别越高,执行的排序也越高,authentication返回的值若为true则放行,反之则直接被拦截不再往下响应

/** * @author linzf * @since 2020/7/14 * 类描述:请求拦截器 */public class WebsocketSecurityImpl implements WebsocketSecurity {
/** * 这个authService就是我们平时在spring里面写的service **/ @Autowired private AuthService authService; @Override public int level() {
return 10; } @Override public Boolean authentication(ChannelHandlerContext ctx, SocketRequest socketRequest) {
Boolean isPass = authService.authUrl(socketRequest.getUrl()); System.out.println("----我在这里做了一个模拟的鉴权过程---"); if(!isPass){
ctx.channel().writeAndFlush(new TextWebSocketFrame(JsonUtils.objToJson(new SocketResponse(HttpResponseStatus.UNAUTHORIZED.code(), "授权不通过!")))); } return isPass; }}

4、编写第一个监听器

只需实现WebSocketHandlerListenter接口即可,level方法主要用于界定这个监听器的执行的顺序,数字越大则级别越高,执行的排序也越高,channelInactive当通道关闭的时候执行的方法,handleShake当websocket尝试握手的时候执行的方法。

/** * @author linzf * @since 2020/7/14 * 类描述: 通道关闭监听器 */public class WebSocketHandlerListenterImpl implements WebSocketHandlerListenter {
/** * 这个webSocketCloseService就是我们平时在spring里面写的service **/ @Autowired private WebSocketCloseService webSocketCloseService; @Override public int level() {
return 0; } /** * 功能描述: 当浏览器端的通道关闭的时候的响应处理方法 * * @param ctx 当前的通道对象 */ @Override public void channelInactive(ChannelHandlerContext ctx) {
System.out.println("当前关闭的通道的id是:" + ctx.channel().id().asLongText()); webSocketCloseService.removeChannel(ctx.channel().id().asLongText()); } @Override public void handleShake(ChannelHandlerContext ctx) {
System.out.println("当前开启的通道的id是:" + ctx.channel().id().asLongText()); }}

5、编写第一个前端响应请求

前端采用的是vue响应的方式,不过本质上还是用的是浏览器的本身自带的websocket因此写法上没什么差别,只是此处在与后端进行websocket交互的

时候需要按照一定的格式往后端提交数据,格式如下:

{
'url': 后端的请求地址, 'params': 请求的JSON数据}

例如本例中写了一个后端请求的地址是/user/getUserVoByUserId那我们此处的请求地址就是这个地址,同时后端的这个方法的入参是userId,那么我们这边的params的JSON数据

的格式就是{'userId':'123'}那么最终我们请求上来的数据格式如下:

{
'url': '/user/getUserVoByUserId', 'params': {
'userId':'123'}}

最后直接调用我们的websocket对象的send方法请求后端即可。

6、编写前端的实现

配置

属性 默认值 说明
websocket.port 8399 websocket的端口号
websocket.thread.boss 12 boss的线程数
websocket.thread.work 12 工作线程数
websocket.action ws websocket的响应的地址

通过application.yml 进行配置

websocket:   port: 8399   action: ws   thread:        boss: 12        work: 12

版本更新

1.0.3.RELEASE

  • 【发布失败】由于1.0.2发布失败,因此补发1.03版本。

1.0.2.RELEASE

  • 【BUG修复】修复netty与tomcat集成部署时,由于netty的启动导致tomcat启动失败。

1.0.1.RELEASE

  • @WebSocketController注解的类支持构造方法的方式注入的支持。
  • 新增@WebSocketRequestParam支持入参的自定义。

转载地址:http://eakvf.baihongyu.com/

你可能感兴趣的文章
Spring Cloud Spring Boot b2b2c 微服务 多商家入驻直播商城之Maven 项目模板
查看>>
mac || Linux 命令行下实现批量重命名
查看>>
java常用类 String面试题
查看>>
Windows10下的powershell美化教程
查看>>
利用ffmpeg合并音频和视频
查看>>
刷好老毛子系统进不了老毛子系统后台的解决办法
查看>>
Parallels Desktop 16 不能联网的解决办法
查看>>
ERROR 1292 (22007): Incorrect datetime value: ‘2002‘ for column ‘出版日期‘ at row 1
查看>>
SLAM中TUM数据集更改图片名字
查看>>
手把手教你--jquery chosen插件的使用和API(html下拉框美化)
查看>>
手把手教你--jsp读取配置文件(properties文件)--(JSTL的fmt:setBundle和fmt:message读取properties文件)
查看>>
手把手教你--JAVA微信支付(H5支付)
查看>>
solr修改schema文件(solr修改配置文件)
查看>>
Bootstrap datetimepicker日期时间插件使用方法(日期时间选择器)
查看>>
字体图标库(Font Awesome)的使用--绝佳的图标字体库和CSS框架
查看>>
select下拉框分组展示插件的使用--(select-mania插件的使用)
查看>>
Java 8新特性之--lambda表达式的使用和应用
查看>>
Java Lambda表达式的应用--Stream API操作集合框架
查看>>
Java 8新特性之-- Date-Time API(LocalDate/Time/DateTime 日期时间API)
查看>>
省市区三级联动插件Distpicker--前端实现地区三级联动
查看>>