uni-app 封装微信小程序支付请求

const wechatOrder = function wechatOrder(money, successDate, errorData) {
				var that = this;
				var url = '域名路径' + "/order/add";  //这里是下单接口的请求路径
				var data = {
					money: money
				};
				uni.request({
					url: url,
					data: data,
					method: "POST",
					header: {}, //请求头
					success: (res) => {
						if (res.data.code === 200) {
							wechatPay(res.data.msg, money, (res) => {
								successDate(res) 
							}, (err) => {
								errorData(err)
							})
						}
					},
					fail: (err) => {
						return false
					}
				});
			}
		}
		
		function wechatPay(orderId, money, successDate, errorData) {
			var that = this;
			var userinfo = uni.getStorageSync("userinfo").member;
			var url = Vue.prototype.BaseURL + '/pay/wechat'
			var data = {
				orderId: orderId,//订单ID
				openId: openId//用户openid
			};
			uni.request({
				url: url,
				data: data,
				method: "POST",
				header: {},
				success: (res) => {
					if (res.data.code === 200) {
						xcxPay(res.data.data, (res) => {
							successDate(res)
						}, (err) => {
							errorData(err)
						})
					}
				},
				fail: (err) => {
					console.log('请求错误信息:  ' + err);
				}
			});
		}
		
		/**
		 * 调用微信支付接口
		 */
		function xcxPay(result, successDate, errorData) {
			uni.requestPayment({
				'nonceStr': result.nonceStr,
				'package': result.package, // 这里的值必须是 prepay_id=XXXXXXXXX 的格式,否则也会报错
				'signType': 'MD5',
				'timeStamp': result.timeStamp, // 时间戳必须是字符串,否则会报错
				'paySign': result.sign,
				'success': function(res) {
					// 这里应该是 res.errMsg , 跟公众号的支付返回的参数不一样,公众号是 err_msg, 就因为没注意到这个,折腾了很长时间
					console.log(res)
					if (res.errMsg == "requestPayment:ok") { // 调用支付成功
						successDate(true)
						// uni.showToast({
						// 	title: '支付成功',
						// 	icon: 'success',
						// 	success(res) {
		
						// 	}
						// });
					}
				},
				'fail': function(res) {
					errorData(false)
				},
				'complete': function(res) {
					// console.log('paycomplete-->', res)
					// return false
				}
			})
		}
		
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值