网站首页 > 技术文章 正文
今天遇到一个需求,需要对接第三方扫码跳转。一种方案是前端页面轮询后端服务,但是这种空轮询会虚耗资源,实时性比较差而且也不优雅。所以决定使用另一种方案,websocket。以前就知道websocket,属于全双工长连接,适合实时在线聊天,浏览器之间的协同编辑工作,多人在线游戏等场景。
但是一直没机会用,今天正好可以使用一下。
简单记录一下步骤,亲测可用。
- 引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
springboot已经非常贴心的为我们编写好了starter
- 配置config
@Configuration
public class WebSocketConfig {
@Bean
public ServerEndpointExporter serverEndpointExporter() {
return new ServerEndpointExporter();
}
}
必须有这个config,把ws服务暴露出去。
- 编写webSocket server
@Slf4j
@Component
@ServerEndpoint("/webSocket/{id}")
public class MyWebSocket {
/**
* 静态变量 用来记录当前在线连接数
*/
private static int onlineCount = 0;
/**
* 服务端与单一客户端通信 使用Map来存放 其中标识Key为id
*/
private static ConcurrentMap<String, MyWebSocket> webSocketMap = new ConcurrentHashMap<>();
//不需要区分可使用set
//private static CopyOnWriteArraySet<WebSocketTest> webSocketSet = new CopyOnWriteArraySet<WebSocketTest>();
public static ConcurrentMap<String, MyWebSocket> getWebSocketMap() {
return webSocketMap;
}
/**
* 与某个客户端的连接会话 需要通过它来给客户端发送数据
*/
private Session session;
/**
* 连接建立成功调用的方法
*
* @param session 可选的参数 session为与某个客户端的连接会话 需要通过它来给客户端发送数据
*/
@OnOpen
public void onOpen(Session session, @PathParam("id") String id) {
this.session = session;
webSocketMap.put(id, this);
addOnlineCount();
log.info("有新连接加入,当前在线数为" + getOnlineCount());
}
/**
* 连接关闭调用的方法
*/
@OnClose
public void onClose() {
Map<String, String> map = session.getPathParameters();
webSocketMap.remove(Integer.parseInt(map.get("id")));
subOnlineCount();
log.info("有一连接关闭!当前在线数为" + getOnlineCount());
}
/**
* 收到客户端消息后调用的方法
*
* @param message 客户端发送过来的消息
* @param session 可选的参数
*/
@OnMessage
public void onMessage(String message, Session session) {
log.info("来自客户端 " + session.getId() + " 的消息:" + message);
}
/**
* 发生错误时调用
*
* @param session
* @param error
*/
@OnError
public void onError(Session session, Throwable error) {
log.error("LoginResultWebSocket 发生错误");
error.printStackTrace();
}
/**
* 发送消息
*
* @param message
* @throws IOException
*/
public void sendMessage(String message) throws IOException {
this.session.getBasicRemote().sendText(message);
}
public static synchronized int getOnlineCount() {
return onlineCount;
}
public static synchronized void addOnlineCount() {
MyWebSocket.onlineCount++;
}
public static synchronized void subOnlineCount() {
MyWebSocket.onlineCount--;
}
}
4.编写测试页面
页面代码就不贴了,网上很多,需要的可以看github,地址在文章最后。就是一个按钮打开socket链接。一个按钮向后端发送消息。一个用来展示从服务端收到的消息的p标签。
点击发送消息后,
可以看到,server端已经接收到。
然后测试页面也可以接收到消息。我写了一个请求,触发一下sendMessage方法。
总结:
websocket入门使用还是很简单的,也很有趣。可以用来写个在线聊天室demo。
源码地址:
技术笔记与开源分享
猜你喜欢
- 2025-05-16 放弃 Websocket 使用 SSE 才发现这些功能两三行代码就搞定了
- 2025-05-16 我与spring webSocket不得不说的事
- 2025-05-16 从零搭建体育比分网站完整步骤
- 2025-05-16 「项目实战」.待办事项之WebSocket Web客户端(一)
- 2025-05-16 springboot 2整合websocket推送消息、数据流、解析pdf图片并压缩
- 2025-05-16 Springboot 整合 Websocket 轻松实现IM及时通讯
- 2025-05-16 现在页面实时聊天都使用Websocket技术实现吗?
- 2025-05-16 Trae验证websocket版本功能
- 2025-05-16 Spring Boot3 竟能如此轻松整合 WebSocket 技术,你还不知道?
- 2025-05-16 零基础快入门WebRTC:基本概念、关键技术、与WebSocket的区别等
你 发表评论:
欢迎- 592℃几个Oracle空值处理函数 oracle处理null值的函数
- 585℃Oracle分析函数之Lag和Lead()使用
- 573℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 570℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 566℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 558℃【数据统计分析】详解Oracle分组函数之CUBE
- 543℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 539℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端懒加载 (49)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)