当前位置: 首页 > wzjs >正文

做笔记的网站源码企业简介模板范文

做笔记的网站源码,企业简介模板范文,俄罗斯乌克兰死亡人数,幼教网站建设分析🚀 苍穹外卖项目中的 WebSocket 实战:实现来单与催单提醒功能 在现代 Web 应用中,实时通信成为提升用户体验的关键技术之一。WebSocket 作为一种在单个 TCP 连接上进行全双工通信的协议,被广泛应用于需要实时数据交换的场景&#…

🚀 苍穹外卖项目中的 WebSocket 实战:实现来单与催单提醒功能

在这里插入图片描述

在现代 Web 应用中,实时通信成为提升用户体验的关键技术之一。WebSocket 作为一种在单个 TCP 连接上进行全双工通信的协议,被广泛应用于需要实时数据交换的场景,如在线聊天、实时通知等。本文将结合苍穹外卖项目,介绍如何使用 WebSocket 实现来单提醒与催单提醒功能。

📖 WebSocket 简介 WebSocket 是一种网络通信协议,允许在客户端和服务器之间建立持久的连接,双方可以随时发送数据。与传统的 HTTP 请求-响应模式不同,WebSocket 提供了更高效的通信方式,特别适用于需要实时交互的应用场景。

🛠️ 项目中 WebSocket 的应用场景 在苍穹外卖项目中,WebSocket 被用于实现以下功能:

  • 来单提醒:当用户下单并支付成功后,系统通过 WebSocket 向商家管理端发送通知,提示有新订单。
    • 催单提醒:用户在等待订单过程中,可以点击“催单”按钮,系统通过 WebSocket 向商家管理端发送催单通知。 这些功能依赖于客户端与服务器之间的实时通信,确保商家能够及时响应用户的需求。

🧱 实现步骤

  1. 引入WebSocket依赖
    pom.xml中添加以下依赖:
<dependency>  <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-websocket</artifactId>  
</dependency>  
  1. 配置WebSocket
    创建配置类WebSocketConfiguration,注册WebSocket组件:
@Configuration  
public class WebSocketConfiguration {  @Bean  public ServerEndpointExporter serverEndpointExporter() {  return new ServerEndpointExporter();  }  
}  
  1. 创建WebSocket服务端
    实现WebSocketServer类,处理连接、消息收发逻辑:
@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) {  sessionMap.put(sid, session);  }  @OnMessage  public void onMessage(String message, @PathParam("sid") String sid) {  // 处理接收到的消息  }  @OnClose  public void onClose(@PathParam("sid") String sid) {  sessionMap.remove(sid);  }  public void sendToAllClient(String message) {  for (Session session : sessionMap.values()) {  try {  session.getBasicRemote().sendText(message);  } catch (Exception e) {  e.printStackTrace();  }  }  }  
}  
  1. 业务逻辑中集成消息发送
  • 订单支付成功提醒
public void paySuccess(String outTradeNo) {  // 更新订单状态  Orders ordersDB = orderMapper.getByNumber(outTradeNo);  Orders orders = Orders.builder()  .id(ordersDB.getId())  .status(Orders.TO_BE_CONFIRMED)  .payStatus(Orders.PAID)  .checkoutTime(LocalDateTime.now())  .build();  orderMapper.update(orders);  // 构造消息并广播  Map<String, Object> map = new HashMap<>();  map.put("type", 1); // 1=来单提醒  map.put("orderId", ordersDB.getId());  map.put("content", "订单号:" + outTradeNo);  String json = JSON.toJSONString(map);  webSocketServer.sendToAllClient(json);  
}  
  • 用户催单提醒
public void reminder(Long id) {  Orders orders = orderMapper.selectByOId(id);  if (orders == null || orders.getStatus() != Orders.TO_BE_CONFIRMED) {  throw new OrderBusinessException("订单状态不允许催单");  }  Map<String, Object> map = new HashMap<>();  map.put("type", 2); // 2=催单提醒  map.put("orderId", id);  map.put("content", "订单号:" + orders.getNumber());  String json = JSON.toJSONString(map);  webSocketServer.sendToAllClient(json);  
}  
  1. 前端消息处理
    建立WebSocket连接并解析通知:
// 初始化连接(clientId为前端用户标识)  
var websocket = new WebSocket("ws://localhost:8080/ws/" + clientId);  // 消息监听  
websocket.onmessage = function(event) {  var data = JSON.parse(event.data);  if (data.type === 1) {  alert("来单提醒:" + data.content);  } else if (data.type === 2) {  alert("催单提醒:" + data.content);  }  
};  

🧪 测试与验证

测试流程:

  1. 启动后端服务与前端页面,建立WebSocket连接;
  2. 模拟用户下单并支付,验证商家端是否弹出“来单提醒”;
  3. 触发用户催单操作,验证是否收到“催单提醒”弹窗。

Nginx配置(如需代理):

location /ws/ {  proxy_pass http://localhost:8080;  proxy_http_version 1.1;  proxy_set_header Upgrade $http_upgrade;  proxy_set_header Connection "Upgrade";  
}  

🧠 总结

通过WebSocket技术,苍穹外卖实现了毫秒级实时通知,显著提升了商家订单处理效率与用户体验。WebSocket在实时通信场景(如在线聊天、数据监控)中具有广泛适用性,是现代Web开发的核心技术之一。


文章转载自:

http://036kO1tK.trsxw.cn
http://GNdAAoTO.trsxw.cn
http://v10dUvzc.trsxw.cn
http://xATO7uNM.trsxw.cn
http://zvpKxldU.trsxw.cn
http://CNLCFuHA.trsxw.cn
http://vPyn0AfM.trsxw.cn
http://298HhFZE.trsxw.cn
http://36Vo1LMB.trsxw.cn
http://V8tu09Iq.trsxw.cn
http://XRCMvoCr.trsxw.cn
http://x9xtH0s4.trsxw.cn
http://g0tnIpvr.trsxw.cn
http://jiXdhtih.trsxw.cn
http://YCAsjhSI.trsxw.cn
http://gQhnnEyx.trsxw.cn
http://hLfhkZ8C.trsxw.cn
http://yMkjY1IT.trsxw.cn
http://OwgsTwmG.trsxw.cn
http://iVLDDSmq.trsxw.cn
http://XpMJ74ZC.trsxw.cn
http://WlyHHyg6.trsxw.cn
http://3c9JKs1n.trsxw.cn
http://rdAYwdzj.trsxw.cn
http://Xj9AuUpn.trsxw.cn
http://mXb8Qr5a.trsxw.cn
http://iKLctNgW.trsxw.cn
http://Vhe10lCq.trsxw.cn
http://whZJucsY.trsxw.cn
http://LxhMPhy7.trsxw.cn
http://www.dtcms.com/wzjs/609900.html

相关文章:

  • 网站建设哪里最好ftp网站上传之后怎么办
  • 制作网站哪家便宜北京平面设计工作室
  • 跨境电商自己做网站引流wordpress 404宝塔
  • 网站编辑招聘信息sql数据库添加网站
  • 网站建设技术合同手机网站建设专家
  • 最早做弹幕的网站响应式网站模板
  • 上海网站建设网济宁网站建设招聘
  • 山西做网站费用做网站开发平台
  • 东莞医疗网站建设报价在wordpress官网建站
  • 网页商城设计商城网站设计案例国外的域名注册网站
  • 平台式网站模板下载吉林网站模板
  • 做外贸要建什么网站婚庆设计效果图
  • 东莞建英文网站的公司南京紫米网络科技有限公司
  • 自己建网站做代理商iis建好的网站套用模板
  • 网站竞价词怎么做wordpress 文章编辑框插件
  • 大学校园网站建设的新开传奇最大网站999
  • 江苏网站建设定制外包网站制作
  • 晋江市住房和城乡建设局网站是多少广州网站优化推广方案
  • 深圳网站建设大概多少钱上海网站原型设计
  • 浙江英文网站建设iis怎么搭建设计网站
  • 自己做qq头像网站岷县城乡建设局网站
  • 建设电影播放网站全国设计网站公司网站
  • 成都网站制作怎么收费哈尔滨企业建站
  • 校园网站建设依据注册公司成本多少钱
  • 网站开发 加二维扫码安阳专业做网站公司
  • wordpress搬迁后台总跳转到老网站苏州有哪些互联网大厂
  • 论前端对网站建设的重要性网站后台账号密码忘记了
  • 邢台做移动网站价格网站如何建立
  • 网站出现转站怎么办安徽合肥制作网站公司
  • uc官方网站开发者中心网站开发中视屏怎样编辑到网页上