苍穹外卖day10总结

1.Spring Task

1.介绍

Spring Task Spring框架提供的任务调度工具,可以按照约定的时间自动执行某个代码逻辑。

作用:定时自动执行某段Java代码

应用场景:

信用卡每月还款提醒

银行贷款每月还款提醒

火车票售票系统处理未支付订单

入职纪念日为用户发送通知

2.cron表达式

cron表达式其实就是一个字符串,通过cron表达式可以定义任务触发的时间构成规则:分为67个域,由空格分隔开,每个域代表一个含义每个域的含义分别为:秒、分钟、小时、日、月、周、年(可选)

日和周(周几),往往只能定义一个,另一个用?

cron表达式在线生成器:在线Cron表达式生成器

3.入门案例

Spring Task使用步骤:

导入maven坐标 spring-context(已存在)

启动类添加注解 @EnableScheduling 开启任务调度

自定义定时任务类

2.订单状态定时处理

/**
 * 定时任务类,定时处理订单状态
 */
@Component
@Slf4j
public class OrderTask {
    @Autowired
    private OrderMapper orderMapper;

    /**
     * 处理超时订单的方法
     */
    @Scheduled(cron = "0 * * * * ? ")//每分钟触发一次
    public void processTimeoutOrder(){
        log.info("定时处理超时订单:{}", LocalDateTime.now());
        LocalDateTime time = LocalDateTime.now().plusMinutes(-15);
        //select * from orders where status=? and order_time <(当前时间-15分钟)
        List<Orders> ordersList = orderMapper.getByStatusAndOrderTimeLT(Orders.PENDING_PAYMENT, time);
        if (ordersList !=null && ordersList.size()>0){
            for (Orders orders : ordersList) {
                orders.setStatus(Orders.CANCELLED);
                orders.setCancelReason("订单超时,自动取消");
                orders.setCancelTime(LocalDateTime.now());
                orderMapper.update(orders);
            }
        }

    }

    /**
     * 处理一直处于派送中的订单
     */
    @Scheduled(cron = "0 0 1 * * ?")//每天凌晨一点触发一次
    public void processDeliveryOrder(){
        log.info("定时处理处于派送中的订单:{}",LocalDateTime.now());
        LocalDateTime time = LocalDateTime.now().plusMinutes(-60);
        //处理上一个工作日一直处于派送中的订单
        List<Orders> ordersList = orderMapper.getByStatusAndOrderTimeLT(Orders.DELIVERY_IN_PROGRESS, time);
        if (ordersList !=null && ordersList.size()>0){
            for (Orders orders : ordersList) {
                orders.setStatus(Orders.COMPLETED);
                orderMapper.update(orders);
            }
        }

    }
}

3.WebSocket

1.介绍

WebSocket 是基于 TCP 的一种新的网络协议。它实现了浏览器与服务器全双工通信——浏览器和服务器只需要完成一次握手,两者之间就可以创建持久性的连接, 并进行双向数据传输。

HTTP协议和WebSocket协议对比

HTTP短连接

WebSocket长连接

HTTP通信是单向的,基于请求响应模式

WebSocket支持双向通信

HTTPWebSocket底层都是TCP连接

应用场景视频弹幕、网页聊天、体育实况更新、股票基金报价实时更新

2.入门案例

实现步骤:

直接使用websocket.html页面作为WebSocket客户端

导入WebSocketmaven坐标

导入WebSocket服务端组件WebSocketServer,用于和客户端通信

导入配置类WebSocketConfiguration,注册WebSocket的服务端组件

导入定时任务类WebSocketTask,定时向客户端推送数据

既然WebSocket支持双向通信,功能看似比HTTP强大,那么我们是不是可以基于WebSocket开发所有的业务功能?

WebSocket缺点:

服务器长期维护长连接需要一定的成本

各个浏览器支持程度不一

WebSocket 是长连接,受网络限制比较大,需要处理好重连

结论:WebSocket并不能完全取代HTTP,它只适合在特定的场景下使用

4.来单提醒

1.需求分析与设计

设计:

通过WebSocket实现管理端页面和服务端保持长连接状态

当客户支付后,调用WebSocket的相关API实现服务端向客户端推送消息

客户端浏览器解析服务端推送的消息,判断是来单提醒还是客户催单,进行相应的消息提示和语音播报

约定服务端发送给客户端浏览器的数据格式为JSON,字段包括:typeorderIdcontent

- type 为消息类型,1为来单提醒 2为客户催单

- orderId 为订单id

- content 为消息内容

2.代码开发

OrderServiceImp:

OrderServiceImpl中注入WebSocketServer对象,修改paySuccess方法,加入如下代码:

5.客户催单

1.需求分析与设计

设计:

通过WebSocket实现管理端页面和服务端保持长连接状态

当用户点击催单按钮后,调用WebSocket的相关API实现服务端向客户端推送消息

客户端浏览器解析服务端推送的消息,判断是来单提醒还是客户催单,进行相应的消息提示和语音播报

约定服务端发送给客户端浏览器的数据格式为JSON,字段包括:typeorderIdcontent

- type 为消息类型,1为来单提醒 2为客户催单

- orderId 为订单id

- content 为消息内容

2.代码开发

OrderController

   /**
     * 用户催单
     * @param id
     * @return
     */
    @GetMapping("/reminder/{id}")
    @ApiOperation("用户催单")
    public Result reminder(@PathVariable("id") Long id){
        orderService.reminder(id);
        return Result.success();
    }

OrderServiceImpl

 /**
     * 用户催单
     * @param id
     */
    public void reminder(Long id) {
        //查询订单是否存在
        Orders orders = orderMapper.getById(id);
        if (orders==null){
            throw new OrderBusinessException(MessageConstant.ORDER_STATUS_ERROR);
        }
        //基于webSocket实现催单
        Map map=new HashMap();
        map.put("type",2);//2代表用户催单
        map.put("orderId",id);
        map.put("content","订单号"+orders.getNumber());
        webSocketServer.sendToAllClient(JSON.toJSONString(map));

    }

### 苍穹外卖 Day10 学习资料与教程 #### 订单状态定时处理 在苍穹外卖项目的第10天学习中,重点涉及订单状态的定时处理功能。此部分通过 `Spring Task` 实现定时任务的功能,能够定期扫描数据库中的订单表并更新其状态。例如,当某个订单超过指定时间未被接单时,可以将其标记为超时状态[^1]。 以下是实现订单状态定时处理的核心代码片段: ```java @Scheduled(cron = "0 0/1 * * * ?") // 每分钟执行一次 public void updateOrderStatus() { List<Order> pendingOrders = orderRepository.findByStatus("PENDING"); for (Order order : pendingOrders) { if (order.getCreateTime().plusMinutes(30).isBefore(LocalDateTime.now())) { // 超过30分钟未接单 order.setStatus("TIMEOUT"); // 更新为超时状态 orderRepository.save(order); } } } ``` #### 来电提醒功能 来电提醒功能旨在通知商家有新的订单到达。通常可以通过 WebSocket 技术实现实时通信,在客户下单后立即向商家端发送消息提示新订单的到来[^5]。 核心逻辑如下所示: ```java @Configuration @EnableScheduling public class WebSocketConfig implements SchedulingConfigurer { @Override public void configureTasks(ScheduledTaskRegistrar taskRegistrar) { taskRegistrar.addTriggerTask( () -> notifyNewOrder(), // 执行的任务方法 triggerContext -> { LocalDateTime nextExecutionTime = LocalDateTime.now().plusSeconds(1); // 下次触发时间为当前时间加一秒 return Date.from(nextExecutionTime.atZone(ZoneId.systemDefault()).toInstant()); }); } private void notifyNewOrder() { Order newOrder = orderService.findLatestOrderByStatus("NEW"); if (newOrder != null) { webSocketServer.sendMessage(newOrder.toString()); // 推送最新订单到前端 } } } ``` #### 客户催单机制 为了提升用户体验,项目还实现了客户催单功能。如果顾客认为自己的订单等待时间过长,则可通过应用发起催促请求。后台收到此类请求后会重新调整优先级或将信息反馈给配送员或厨房工作人员。 --- ### 总结 综上所述,苍穹外卖 Day10 的主要内容围绕着 **订单状态定时处理**、**来电提醒** 和 **客户催单** 展开。这些模块不仅增强了系统的自动化能力,也改善了用户的交互体验。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值