ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

微信支付

2020-11-23 12:03:25  阅读:260  来源: 互联网

标签:const success 微信 支付 res orderType orderNo wx


支付步骤:

  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 };

标签:const,success,微信,支付,res,orderType,orderNo,wx
来源: https://blog.csdn.net/w_D_lufei/article/details/109991338

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有