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

news2025/5/20 9:01:45

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

在这里插入图片描述

在现代 Web 应用中,实时通信成为提升用户体验的关键技术之一。WebSocket 作为一种在单个 TCP 连接上进行全双工通信的协议,被广泛应用于需要实时数据交换的场景,如在线聊天、实时通知等。本文将结合苍穹外卖项目,介绍如何使用 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://www.coloradmin.cn/o/2379851.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Win10 安装单机版ES(elasticsearch),整合IK分词器和安装Kibana

一. 先查看本机windows是否安装了ES(elasticsearch)&#xff0c;检查方法如下&#xff1a; 检查进程 按 Ctrl Shift Esc 组合键打开 “任务管理器”。在 “进程” 选项卡中&#xff0c;查看是否有 elasticsearch 相关进程。如果有&#xff0c;说明系统安装了 ES。 检查端口…

【Redis】List 列表

文章目录 初识列表常用命令lpushlpushxlrangerpushrpushxlpop & rpoplindexlinsertllen阻塞操作 —— blpop & brpop 内部编码应用场景 初识列表 列表类型&#xff0c;用于存储多个字符串。在操作和实现上&#xff0c;类似 C 的双端队列&#xff0c;支持随机访问(O(N)…

JUC入门(四)

ReadWriteLock 代码示例&#xff1a; package com.yw.rw;import java.util.HashMap; import java.util.Map; import java.util.concurrent.locks.ReentrantReadWriteLock;public class ReadWriteDemo {public static void main(String[] args) {MyCache myCache new MyCache…

【HarmonyOS 5】鸿蒙mPaaS详解

【HarmonyOS 5】鸿蒙mPaaS详解 一、mPaaS是什么&#xff1f; mPaaS 是 Mobile Platform as a Service 的缩写&#xff0c;即移动开发平台。 蚂蚁移动开发平台mPaaS &#xff0c;融合了支付宝科技能力&#xff0c;可以为移动应用开发、测试、运营及运维提供云到端的一站式解决…

无法加载文件 E:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本

遇到“无法加载文件 E:\Program Files\nodejs\npm.ps1,因为在此系统上禁止运行脚本”这类错误&#xff0c;通常是因为你的 PowerShell 执行策略设置为不允许运行脚本。在 Windows 系统中&#xff0c;默认情况下&#xff0c;出于安全考虑&#xff0c;PowerShell 可能会阻止运行未…

【C++模板与泛型编程】实例化

目录 一、模板实例化的基本概念 1.1 什么是模板实例化&#xff1f; 1.2 实例化的触发条件 1.3 实例化的类型 二、隐式实例化 2.1 隐式实例化的工作原理 2.2 类模板的隐式实例化 2.3 隐式实例化的局限性 三、显式实例化 3.1 显式实例化声明&#xff08;extern templat…

什么是RDMA?

什么是RDMA&#xff1f; RDMA(RemoteDirect Memory Access)技术全称远程直接内存访问&#xff0c;就是为了解决网络传输中服务器端数据处理的延迟而产生的。它将数据直接从一台计算机的内存传输到另一台计算机&#xff0c;无需双方操作系统的介入。这允许高吞吐、低延迟的网络…

ASIC和FPGA,到底应该选择哪个?

ASIC和FPGA各有优缺点。 ASIC针对特定需求&#xff0c;具有高性能、低功耗和低成本&#xff08;在大规模量产时&#xff09;&#xff1b;但设计周期长、成本高、风险大。FPGA则适合快速原型验证和中小批量应用&#xff0c;开发周期短&#xff0c;灵活性高&#xff0c;适合初创企…

Python学习笔记--使用Django操作mysql

注意&#xff1a;本笔记基于python 3.12&#xff0c;不同版本命令会有些许差别&#xff01;&#xff01;&#xff01; Django 模型 Django 对各种数据库提供了很好的支持&#xff0c;包括&#xff1a;PostgreSQL、MySQL、SQLite、Oracle。 Django 为这些数据库提供了统一的调…

计算机视觉设计开发工程师学习路线

以下是一条系统化的计算机视觉&#xff08;CV&#xff09;学习路线&#xff0c;从基础到进阶&#xff0c;涵盖理论、工具和实践&#xff0c;适合逐步深入&#xff0c;有需要者记得点赞收藏哦&#xff1a; 相关学习&#xff1a;python深度学习&#xff0c;python代码定制 python…

STM32实战指南:DHT11温湿度传感器驱动开发与避坑指南

知识点1【DHT11的概述】 1、概述 DHT是一款温湿度一体化的数字传感器&#xff08;无需AD转换&#xff09;。 2、驱动方式 通过单片机等微处理器简单的电路连接就能实时采集本地湿度和温度。DHT11与单片机之间采用单总线进行通信&#xff0c;仅需要一个IO口。 相对于单片机…

【android bluetooth 协议分析 01】【HCI 层介绍 8】【ReadLocalVersionInformation命令介绍】

1. HCI_Read_Local_Version_Information 命令介绍 1. 功能&#xff08;Description&#xff09; HCI_Read_Local_Version_Information 命令用于读取本地 Bluetooth Controller 的版本信息&#xff0c;包括 HCI 和 LMP 层的版本&#xff0c;以及厂商 ID 和子版本号。 这类信息用…

esp32课设记录(四)摩斯密码的实现 并用mqtt上传

摩斯密码(Morse Code)是一种通过点(.)和划(-)组合来表示字符的编码系统。下面我将在esp32上实现摩斯密码的输入&#xff0c;并能够发送到mqtt的broker。 先捋一下逻辑&#xff0c;首先esp32的按键已经编写了短按与长按功能&#xff0c;这将是输出摩斯密码点和划的基础。然后当2…

「HHT(希尔伯特黄变换)——ECG信号处理-第十三课」2025年5月19日

一、引言 心电信号&#xff08;ECG&#xff09;是反映心脏电活动的重要生理信号&#xff0c;其特征提取对于心脏疾病的诊断和监测具有关键意义。Hilbert - Huang Transform&#xff08;HHT&#xff09;作为一种强大的信号处理工具&#xff0c;在心电信号特征提取领域得到了广泛…

前端(vue)学习笔记(CLASS 6):路由进阶

1、路由的封装抽离 将之前写在main.js文件中的路由配置与规则抽离出来&#xff0c;放置在router/index.js文件中&#xff0c;再将其导入回main.js文件中&#xff0c;即可实现路由的封装抽离 例如 //index.js import { createMemoryHistory, createRouter } from vue-routerim…

GPT-4.1特点?如何使用GPT-4.1模型,GPT-4.1编码和图像理解能力实例展示

几天前&#xff0c;OpenAI在 API 中推出了三个新模型&#xff1a;GPT-4.1、GPT-4.1 mini 和 GPT-4.1 nano。这些模型的性能全面超越 GPT-4o 和 GPT-4o mini(感觉这个GPT-4.1就是GPT-4o的升级迭代版本)&#xff0c;主要在编码和指令跟踪方面均有显著提升。还拥有更大的上下文窗口…

写一段图片平移的脚本

问题描述&#xff1a; 写一段图片平移的脚本。 平移就是将对象换一个位置。如果你要沿方向移动&#xff0c;移动的距离是&#xff0c;你可以以下面的方式构建移动矩阵&#xff1a;。 你可以使用Numpy 数组构建这个矩阵&#xff08;数据类型是np.float32&#xff09;&#xf…

【C++】哈希的概念与实现

1.哈希概念 通过某种函数使元素的存储位置与它的关键码之间能够建立一一映射的关系&#xff0c;可以不经过任何比较&#xff0c;一次直接从表中得到要搜索的元素。 当向该结构中&#xff1a; 插入元素&#xff1a; 根据待插入元素的关键码&#xff0c;以此函数计算出该元素的…

Yocto和Buildroot功能和区别

一.介绍 Yocto 和 Buildroot 都是用于嵌入式 Linux 系统开发的工具集&#xff0c;它们的目的是帮助开发者轻松构建定制的 Linux 系统镜像&#xff0c;以便在嵌入式设备上运行。 二.对比 1.Yocto Yocto 是一个开源的嵌入式 Linux 构建系统&#xff0c;它允许开发者创建自定义…

详解RabbitMQ工作模式之发布订阅模式

目录 发布订阅模式 概念 概念介绍 特点和优势 应用场景 注意事项 代码案例 引入依赖 常量类 编写生产者代码 编写消费者1代码 运行代码 发布订阅模式 概念 RabbitMQ的发布订阅模式&#xff08;Publish/Subscribe&#xff09;是一种消息传递模式&#xff0c;它允许消…