微信支付

支付步骤:

  1. 先传订单信息到后台,拿取后台返回的数据
  2. 调用微信支付接口wx.requestPayment,用拿到的数据进行对应的填写

微信支付参考地址:
https://developers.weixin.qq.com/miniprogram/dev/api/open-api/payment/wx.requestPayment.html

import { appId } from '../config/config';
import getOrderRes from '../resource/wxpay';

const defaultSuccessCallback = (res, backUrl = '/pages/tabbar/sevices/index') => {
  wx.redirectTo({
    url: `/pages/wxpay/success/index?backUrl=${backUrl}`,
  });
};

const defaultFailCallback = (res) => {
  const { orderNo, orderType } = res;
  wx.redirectTo({
    url: `/pages/wxpay/fail/index?orderNo=${orderNo}&orderType=${orderType}`,
  });
};

const wxpay = ({
  orderNo: orderNo,
  orderType: orderType,
  success: successCallback = defaultSuccessCallback,
  fail: failCallback = defaultFailCallback,
}) => {
  wx.login({
    async success({ code }) {
      if (code) {
        const { data } = await getOrderRes.getOrderRes({ code, orderNo, orderType, appId });
        if (!data) {
          successCallback({ result: '支付成功' });
        } else {
          toPay({
            orderInfo: data,
            orderNo,
            orderType,
            success: successCallback,
            fail: failCallback,
          });
        }
      } else {
        console.log('登录code获取失败!');
      }
    },
  });
};

const toPay = ({
  orderInfo,
  orderNo,
  orderType,
  success: successCallback = defaultSuccessCallback,
  fail: failCallback = defaultFailCallback,
}) => {
  const { nonceStr, packageValue, paySign, timeStamp, appId } = orderInfo;
  wx.requestPayment({
    appId,
    timeStamp,
    nonceStr,
    package: packageValue,
    signType: 'MD5',
    paySign,
    success(res) {
      successCallback((res = { result: res }));
    },
    fail(res) {
      failCallback((res = { orderNo, orderType, result: res }));
    },
  });
};


export { wxpay, toPay };

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值