WebSocket双向通信详解及实战应用
创作时间:
作者:
@小白创作中心
WebSocket双向通信详解及实战应用
引用
CSDN
1.
https://blog.csdn.net/m0_74963840/article/details/140407723
WebSocket是一种在单个TCP连接上进行全双工通信的协议,它允许服务器与客户端之间进行实时、双向的数据传输。本文将详细介绍WebSocket的基础概念、使用方法,并通过一个外卖催单和来单提醒的实际应用场景,帮助读者深入理解WebSocket技术。
WebSocket基础使用
WebSocket小说明:
作用
浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接,并进行双向数据传输。
WebSocket与HTTP最大的区别
- HTTP通信是单向的,基于请求响应模式
- WebSocket支持双向通信。实现长连接
适用场景:
消息通信,视频弹幕,实时信息,等双向通信的使用需求
使用:
引入maven依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
使用一个封装好的使用工具类:
package com.sky.websocket;
import org.springframework.stereotype.Component;
import javax.websocket.OnClose;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.PathParam;
import javax.websocket.server.ServerEndpoint;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
/**
* WebSocket服务
*/
@Component
@ServerEndpoint("/ws/{sid}")
public class WebSocketServer {
//存放会话对象
private static Map<String, Session> sessionMap = new HashMap();
/**
* 连接建立成功调用的方法
*/
@OnOpen
public void onOpen(Session session, @PathParam("sid") String sid) {
System.out.println("客户端:" + sid + "建立连接");
sessionMap.put(sid, session);
}
/**
* 收到客户端消息后调用的方法
*
* @param message 客户端发送过来的消息
*/
@OnMessage
public void onMessage(String message, @PathParam("sid") String sid) {
System.out.println("收到来自客户端:" + sid + "的信息:" + message);
}
/**
* 连接关闭调用的方法
*
* @param sid
*/
@OnClose
public void onClose(@PathParam("sid") String sid) {
System.out.println("连接断开:" + sid);
sessionMap.remove(sid);
}
/**
* 群发
*
* @param message
*/
public void sendToAllClient(String message) {
Collection<Session> sessions = sessionMap.values();
for (Session session : sessions) {
try {
//服务器向客户端发送消息
session.getBasicRemote().sendText(message);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
小案例:实现客户端与服务器的双向通信
package com.sky.task;
import com.sky.websocket.WebSocketServer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
@Component
public class WebSocketTask {
@Autowired
private WebSocketServer webSocketServer;
/**
* 通过WebSocket每隔5秒向客户端发送消息
*/
@Scheduled(cron = "0/5 * * * * ?")
public void sendMessageToClient() {
webSocketServer.sendToAllClient("这是来自服务端的消息:" + DateTimeFormatter.ofPattern("HH:mm:ss").format(LocalDateTime.now()));
}
}
实际使用:苍穹外卖客户催单,与来单提醒
第一步:服务端与客户端建立连接
第二步:在需要推送消息的类方法上。创建号消息对象后调用封装好的WebSocketServer即可推送
来单提醒:将提醒信息转换成json格式的数据后就可直接调用WebSocketServer完成向浏览器客户端推送消息
/**
* 支付成功,修改订单状态
*
* @param outTradeNo
*/
public void paySuccess(String outTradeNo) {
// 根据订单号查询订单
Orders ordersDB = orderMapper.getByNumber(outTradeNo);
// 根据订单id更新订单的状态、支付方式、支付状态、结账时间
Orders orders = Orders.builder()
.id(ordersDB.getId())
.status(Orders.TO_BE_CONFIRMED)
.payStatus(Orders.PAID)
.checkoutTime(LocalDateTime.now())
.build();
orderMapper.update(orders);
//通过websocket向客户端浏览器推送消息type orderId content
Map map=new HashMap<>();
map.put("type",1);
map.put("orderId",ordersDB.getId());
map.put("content,订单号",outTradeNo);
String json=JSON.toJSONString(map);
webSocketServer.sendToAllClient(json);
}
客户催单:将催单信息转换成json格式的数据后就可直接调用WebSocketServer完成向浏览器客户端推送消息
/**
* 客户催单
* @param id
*/
@Override
public void reminder(Long id) {
// 根据id查询订单
Orders ordersDB = orderMapper.getById(id);
// 校验订单是否存在
if (ordersDB == null) {
throw new OrderBusinessException(MessageConstant.ORDER_STATUS_ERROR);
}
Map map=new HashMap<>();
map.put("type",2);
map.put("order",id);
map.put("content","订单号:" + ordersDB.getNumber());
//通过webSocket向客户端浏览器推送消息
webSocketServer.sendToAllClient(JSON.toJSONString(map));
}
效果:在用户下单或者催单后商家服务端就会出现提醒
热门推荐
GPU的进化之旅:从过去到未来
秋冬自驾游:从盐池到银川的绝美路线推荐
待定系数法详解
刘看山新年头像:传递健康祝福
猫牙米和普通大米的区别
猫牙米到底是啥啊
被打后如何依法维权?律师教你三招!
2025淮安区萧湖春节活动全攻略:无人机表演、花船巡游等你来!
广东省市监局发布预制菜标准体系,为年夜饭安全保驾护航
洪湖市预制菜产业助力乡村振兴
血压高了,怎么吃?推荐给您两种膳食模式
深度学习+电子喉镜:诊断新突破!
AI+窄带成像:电子喉镜检查的新突破
宁都县:预制菜产业助力乡村振兴的“美味”实践
历史的尘埃‖正月初五迎财神...
全脂牛奶自制淡奶油,健康又美味!
圣诞节自制淡奶油甜品教程:从入门到精通
党参与茯苓:中医调理肺气肿的常用组合
冬季养生必备:肺气肿患者的营养秘籍
《中国中药杂志》发布最新研究:补肺丸治疗肺气肿效果显著
洪都机械厂搬迁:如何留住城市记忆?
电子喉镜高清成像技术新突破!
电子鼻咽喉镜:发现早期疾病的利器
南宁⇌深圳,将2.5小时可达!广西多条铁路公路通道传来好消息!
推荐10部高分体育电影,热血励志,每一部都值得反复观看!
超好看的五部国产现代剧,部部都是好评如潮,收藏起来慢慢看!
淡奶油纸杯蛋糕,一口就上瘾!
2025年大年初一拜年文案:用创意和温暖点亮你的祝福
春节拜年新姿势:古风文案大比拼!
朱广权拜年文案:当传统遇上创意,一段走心的新春祝福