苍穹外卖 遇到的问题及解决方法 (包含跳过微信支付+新订单没有提示和声音)

1、compile编译后,运行报错 ----> 已解决

尝试的解决办法

  • ①在application-dev.yml里,把username和password改成自己的 — 还是报错
    在这里插入图片描述
  • 更改pom.xml里lombok和springboot的版本 — 还是报错
    在这里插入图片描述
  • 最后根据弹幕提示,compile编译后,双击install ---- 成功运行!!!
    在这里插入图片描述

2、yapi网址进不去 ----> 已解决

  • 根据弹幕提示:apifox创建项目后在项目设置->数据管理->导入数据中选择YApi然后选择需要导入的文件就行了
    在这里插入图片描述

3、PageHelper代码解释

在这里插入图片描述
在这里插入图片描述

4、在xxxMapper.xml文件中编写sql语句时,不自动提示/不关联数据库 ----> 已解决

  • 根据弹幕提示:idea设置 -> 语言和参数 -> sql方言 ->全部改为mysql即可,当你idea关联数据库后会有提示
    在这里插入图片描述
    右上角:详情☞本地设置☞调试基础库版本选择2.24.4推送就可以了

5、BeanUtils.copyProperties(shoppingCartDTO,shoppingCart);

将前面属性的值拷贝给后面

6、跳过微信支付

  • 参考这篇博主的文章【跳过微信支付】
  • 导入Day09的代码,最后《检查客户的收货地址是否超出配送范围》这段代码没导入;
  • 由于跳过微信支付,《拒单》有部分代码需要修改
    把if判断里面的退款代码,注释掉,然后把下面的更改订单状态代码放到if里面(因为跳过微信支付,故退款运行不了)。
    在这里插入图片描述

7、跳过微信支付后,导致有新订单没有提示和声音 ----- 已解决

微信支付跳过后,导致无法播报
将代码复制到orderServiceImpl 的payment方法里面
若显示店铺打烊 —> 重启redis即可

Map map = new HashMap();
map.put("type", 1);// 消息类型,1表示来单提醒
//获取订单id
Orders orders=orderMapper.getByNumberAndUserId(orderNumber, userId);
map.put("orderId", orders.getId());
map.put("content", "订单号:" + orderNumber);

// 通过WebSocket实现来单提醒,向客户端浏览器推送消息
webSocketServer.sendToAllClient(JSON.toJSONString(map));
log.info("来单提醒:{}", JSON.toJSONString(map));

在这里插入图片描述

### 实现苍穹外卖小程序的微信支付功能 为了实现苍穹外卖小程序中的微信支付功能,需按照以下流程操作: #### 获取预支付交易会话标识 `prepay_id` 在服务器端通过调用微信支付统一下单接口来获得`prepay_id`。此过程涉及发送HTTP请求至微信支付后台并解析返回的数据以提取必要的支付参数[^1]。 ```javascript // 假设这是从前端传递给后端的信息对象 const orderInfo = { body: "苍穹外卖订单", out_trade_no: generateOutTradeNo(), // 商户订单号 total_fee: calculateTotalFee(), // 订单金额() spbill_create_ip: getClientIp(req), // 客户端IP地址 notify_url: config.notifyUrl, // 支付成功后的回调通知URL trade_type: 'JSAPI', // 交易类型 openid: user.openid // 用户标识 }; function getPrepayId(orderInfo) { const response = await axios.post('https://api.mch.weixin.qq.com/v3/pay/transactions/jsapi', orderInfo); return response.data.prepay_id; } ``` #### 小程序前端发起支付请求 当从小程序页面触发支付行为时,应先向自己的服务端申请获取上述提到的`prepay_id`以及其他必需字段组成的签名包数据结构。之后利用官方提供的`wx.requestPayment()`函数完成实际付款动作。 ```javascript async function payOrder() { try { let res = await wx.cloud.callFunction({ name: 'getPayParams', data: { orderId } }); await wx.requestPayment({ timeStamp: res.result.timeStamp, nonceStr: res.result.nonceStr, package: res.result.packageValue, signType: 'MD5', paySign: res.result.paySign, success(res) {}, fail(err) {} }); } catch (err) { console.error("支付失败", err); } } ``` 以上展示了如何基于RESTful风格设计的服务端逻辑以及客户端的小程序代码片段,共同构成了完整的微信支付集成方案。值得注意的是,在真实环境中还需要处理诸如错误重试机制、安全性验证等问题,并严格参照最的官方文档指导来进行开发工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值