苍穹外卖-如何取消/跳过微信支付功能-实现模拟微信支付

苍穹外卖-如何取消/跳过微信支付功能-实现模拟微信支付

微信支付代码定位(小程序端)

全局搜索/payment 定位到请求方法common\vendor.js

// 订单支付
var paymentOrder = function paymentOrder(params) {return (
    (0, _request.request)({
      url: "/user/order/payment",
      method: 'PUT',
      params: params }));};

可以找到请求/user/order/payment的方法定义

根据paymentOrder方法 全局搜索找到使用该方法的位置common\vendor.js

wx.requestPayment({
	nonceStr: res.data.nonceStr,
	package: res.data.packageStr,
	paySign: res.data.paySign,
	timeStamp: res.data.timeStamp,
	signType: res.data.signType,
	success:function(res){
		wx.showModal({
			title: '提示',
			content: '支付成功',
			success:function(){
				uni.redirectTo({url: '/pages/success/index?orderId=' + _this.orderId });
			}
		})
		console.log('支付成功!')
	}
})

可以定位到小程序向微信服务器发送的支付方法wx.requestPayment

跳过微信支付代码(小程序端)

注释/替换上述微信支付的代码

//  跳过微信支付
wx.showModal({
	 title: '提示',
	 content: '支付成功',
	 success:function(){
	 uni.redirectTo({url: '/pages/success/index?orderId=' + _this.orderId });
 }
})
console.log('支付成功!')
return;

无需向微信服务器发送支付请求,直接弹出支付成功的提示

跳过微信支付代码(后端)

修改UserService.payment的实现方法

public void payment(OrdersPaymentDTO ordersPaymentDTO) {

	Long userId = BaseContext.getCurrentId();
	Orders ordersDB = orderMapper.getByNumberAndUserId(ordersPaymentDTO.getOrderNumber(), userId);
	
	
	Orders order = Orders.builder()
	        .id(ordersDB.getId())
	        .status(Orders.TO_BE_CONFIRMED)
	        .payStatus(Orders.PAID)
	        .checkoutTime(LocalDateTime.now()).build();
	orderMapper.update(order);
}	

修改OrderService中原微信支付的代码,跳过向微信服务器发起预支付请求的过程,直接模拟支付成功

### 实现苍穹外卖小程序的微信支付功能 为了实现苍穹外卖小程序中的微信支付功能,需按照以下流程操作: #### 获取预支付交易会话标识 `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风格设计的服务端逻辑以及客户端的小程序代码片段,共同构成了完整的微信支付集成方案。值得注意的是,在真实环境中还需要处理诸如错误重试机制、安全性验证等问题,并严格参照最新的官方文档指导来进行开发工作。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值