苍穹外卖项目模拟微信支付


前言

视频中的微信支付需要商家认证才能开通,个人做项目只能模拟支付。
思路:
首先,用户点击支付,
其次,后端接收到请求,绕过微信支付接口,直接更新订单状态。
最后,微信小程序前端直接回调支付成功页面 。

链接: 黑马程序员苍穹外卖项目视频


一、微信支付

1.修改 orderServiceImpl的payment 方法跳过调用微信支付接口

修改orderServiceImpl的payment 方法跳过调用微信支付接口

将原本的调用支付接口注销,并生成空jsonObject

        //调用微信支付接口,生成预支付交易单
//        JSONObject jsonObject = weChatPayUtil.pay(
//                ordersPaymentDTO.getOrderNumber(), //商户订单号
//                new BigDecimal(0.01), //支付金额,单位 元
//                "苍穹外卖订单", //商品描述
//                user.getOpenid() //微信用户的openid
//        );
        //生成空jsonObject
        JSONObject jsonObject = new JSONObject();

如图所示:
跳过调用微信支付接口

2.修改 user下的orderController的payment 方法直接更新订单状态

在user下的orderController的payment 方法中直接调用orderService.paySuccess方
法,传入订单号ordersPaymentDTO.getOrderNumber(),直接更新订单的状态。

        //模拟交易成功,修改订单状态
        orderService.paySuccess(ordersPaymentDTO.getOrderNumber());

如图所示:
在这里插入图片描述

3.修改微信小程序代码直接跳转至成功页面

修改 pages.pay.index.js 文件
在小程序前端,支付页面点击支付后直接回调支付成功页面

首先,找到pages文件夹下的pay下的index.js文件
在这里插入图片描述

其次,按快捷键 Ctrl + F 搜索 handleSave 定位到具体位置
如下图所示,注释原来的代码,在具体位置更换代码
在这里插入图片描述

if (res.code === 1) {
      wx.showModal({
        title: '提示',
        content: '支付成功',
        success:function(){
          uni.redirectTo({url: '/pages/success/index?orderId=' + _this.orderId });
        }
      })
      console.log('支付成功!')

二、效果

在微信小程序下单后点击支付可以直接支付成功,数据库中订单的状态也更新成功。

  • 44
    点赞
  • 85
    收藏
    觉得还不错? 一键收藏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值