内容简介:先上图基于spring-boot项目开发的
先上图
基于spring-boot项目开发的
首先创建项目,不多说
依赖如下, springboot版本是 2.1.5
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-undertow</artifactId> </dependency>
配置
添加配置类 WebSocketConfig
代码如下
@Configuration @EnableWebSocket public class WebSocketConfig { @Bean public ServerEndpointExporter serverEndpoint() { return new ServerEndpointExporter(); } }
添加处理连接和处理消息类 MyWebSocket
@ServerEndpoint(value = "/websocket") @Component public class MyWebSocket { //在线人数 private static int online = 0; //所有的对象,用于群发 public static List<MyWebSocket> webSockets = new CopyOnWriteArrayList<>(); //会话 private Session session; public Session getSession() { return session; } //建立连接 @OnOpen public void onOpen(Session session) { online++; webSockets.add(this); this.session = session; } //连接关闭 @OnClose public void onClose() { online--; webSockets.remove(this); } //收到客户端的消息 @OnMessage public String onMessage(String text, Session session) { return "client message: " + text; } }
原接文链: https://tomoya92.github.io/2019/05/27/spring-boot-websocket/
客户端
if (window.WebSocket) { // Create WebSocket connection. const socket = new WebSocket('ws://localhost:8080/websocket'); // Connection opened socket.addEventListener('open', function (event) { socket.send('Hello Server!'); }); // Connection closed socket.addEventListener('close', function (event) { socket.send('I am leave!'); }); // Listen for messages socket.addEventListener('message', function (event) { console.log(event); }); // 延时给服务端发送一条消息 setTimeout(function() { socket.send('hello world!'); }, 500); }
将上面js放在一个js里,启动项目,然后可以看到浏览器控制台里有日志输出
封装
上面已经是一个简单的websocket应用了,如果不嫌麻烦完全可以在客户端将对象转成json字符串发给后台,后台再将接收到的json字符串转成对象来处理,只要前端跟后台能约定好,就没有啥大问题
但是用了 java 怎么能少了封装,再说javax.websocket包里也支持 encoder
, decoder
, 下面来说一下怎么直接接收一个对象
先创建一个用于传输数据的对象
public class Message implements Serializable { private static final long serialVersionUID = 7600555288728686383L; private String type; private Object payload; public Message() { } public Message(String type, Object payload) { this.type = type; this.payload = payload; } public String getType() { return type; } public void setType(String type) { this.type = type; } public Object getPayload() { return payload; } public void setPayload(Object payload) { this.payload = payload; } }
创建 encoder 和 decoder,我这里用的是fastjson包将json字符串和对象互转
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.57</version> </dependency>
MessageEncoder.java
import co.yiiu.pydeploy.util.Message; import com.alibaba.fastjson.JSON; import javax.websocket.Encoder; import javax.websocket.EndpointConfig; public class MessageEncoder implements Encoder.Text<Message> { @Override public String encode(Message o) { return JSON.toJSONString(o); } @Override public void init(EndpointConfig endpointConfig) { } @Override public void destroy() { } }
文原接链: https://tomoya92.github.io/2019/05/27/spring-boot-websocket/
MessageDecoder.java
import co.yiiu.pydeploy.util.Message; import com.alibaba.fastjson.JSON; import javax.websocket.Decoder; import javax.websocket.EndpointConfig; public class MessageDecoder implements Decoder.Text<Message> { @Override public Message decode(String s) { return JSON.parseObject(s, Message.class); } @Override public boolean willDecode(String s) { // 验证json字符串是否合法,合法才会进入decode()方法进行转换,不合法直接抛异常 return JSON.isValid(s); } @Override public void init(EndpointConfig endpointConfig) { } @Override public void destroy() { } }
修改 MyWebSocket.java
类注解,添加上 @ServerEndpoint(value = "/websocket", encoders = {MessageEncoder.class}, decoders = {MessageDecoder.class})
其中 @OnMessage
注解修饰的方法参数就可以用 Message
对象来接收了
//收到客户端的消息 @OnMessage public Message onMessage(Message text, Session session) { System.out.println("client message: " + text.toString()); // 直接将前端发的对象返回给前端显示 return text; }
前端接收到的数据还是字符串,还是要通过 JSON.parse(str)
来转换一下
点对点和群发
点对点发消息要知道对方websocket的session,然后通过 session.getBasicRemote().sendText("text")
方法发送给对方
群发只需要把 MyWebSocket
类中的 webSockets
对象循环再使用点对点的方式发送即可
总结
写 encoder 和 decoder 的时候发现还有 binery 的解码跟编码,也就是说还可以能过自定义编/解码用来传输二进制的数据,这块我没有折腾,有需要了再弄
原文链接:
以上所述就是小编给大家介绍的《springboot项目中使用websocket(javax.websocket包下的)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 使用 MonoRepo 管理前端项目
- 使用 Mkdocs 制作项目文档
- 使用Taro开发项目总结
- 使用 Maven 构建 Java 项目
- 使用gradle构建java项目
- flask使用蓝图规划大型项目
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Google總部大揭密
史蒂芬.李維 / 陳重亨 / 財信 / 2011-11
∣如果有一天,Google的搜尋引擎突然故障 ∣GMAIL信件全數消失 ∣Google Maps、Google Docs、Google行事曆等所有雲端服務全面停擺 ∣我們該怎麼辦?! 歷史上像Google如此成功,且廣受推崇的企業可沒幾家。它改變了網路的使用方式,也成了我們生活不可或缺的一部分。這到底是怎麼辦到的? 《連線》雜誌資深主筆史蒂芬.李維史無前例同時取得LS......一起来看看 《Google總部大揭密》 这本书的介绍吧!