移动端页面调用微信支付

1.话不对说,先来个小漩涡
2.步骤:
(1)第一个接口 创建订单号,并且后端携带电子签名
(2)第二个接口 通过后端返回信息,调用微信支付接口callpay方法
3,上代码

//创建订单,做了一些接口判断,可以根据各自后台协议作出相应更改
          axios.post(allApi.UpdateOrders,{AddressId:addressId,Orders:Orders}
          ).then(function (res) {
            if(res.data.IsSuccess==true){
              //PayType 2支付宝 4离线支付 5微信支付
              axios.post(allApi.PayOrder,{PayType:5,Id:id}
              ).then(function (res) {
                // self.AddOrUpdateAddresses=res.data.Result;
                if(res.data.ErrorCode==7){
                  axios.post('/webapi/Login/GetWxAuthLogin?redirectCode=7',
                  ).then(function (res) {
                    location.href = res.data.Result;
                  }).catch(function (res) {
                    console.log(res)
                  });
                }else {
                  publicFun.funcUrlDel('code');
                  publicFun.funcUrlDel('state');
                  if (res.data.IsSuccess == true) {
                    if (res.data.Result.IsValid == true) {
                      var OpenId = res.data.Result.OpenId;
                      var WxJsApiParam = res.data.Result.WxJsApiParam;
                      var ReturnUrl = res.data.Result.ReturnUrl;
                      var IsNeedPay = res.data.Result.IsNeedPay;
                      if (IsNeedPay == false) {
                        location.href = ReturnUrl;
                      } else {
                        publicFun.callpay(WxJsApiParam, ReturnUrl);
                      }
                    }
                  } else {
                    mui.alert(res.data.ErrorMsg, "", "确定关闭", function () {});
                  }
                }
                console.log(res);
              }).catch(function (res) {
                console.log(res)
              });
            }else {
              mui.alert(res.data.ErrorMsg)
            }
          }).catch(function (res) {
            console.log(res)
          });
        },

4.注意,以上代码此处为重点,通过后台返回数据传入微信支付函数callpay

 var OpenId = res.data.Result.OpenId;
                      var WxJsApiParam = res.data.Result.WxJsApiParam;
                      var ReturnUrl = res.data.Result.ReturnUrl;
                      var IsNeedPay = res.data.Result.IsNeedPay;
                      if (IsNeedPay == false) {
                        location.href = ReturnUrl;
                      } else {
                        publicFun.callpay(WxJsApiParam, ReturnUrl);
                      }

5.微信支付函数

//调用微信JS api 支付
function jsApiCall(wxJsApiParam, returnUrl) {
  WeixinJSBridge.invoke(
    'getBrandWCPayRequest',
    $.parseJSON(wxJsApiParam), //josn串
    function (res) {
      WeixinJSBridge.log(res.err_msg);
      if (res.err_msg == "get_brand_wcpay_request:ok") {
        window.location.href = returnUrl; //成功后跳转到提示页面
      }
    }
  );
}
function callpay(wxJsApiParam, returnUrl) {
  if (typeof WeixinJSBridge == "undefined") {
    if (document.addEventListener) {
      document.addEventListener('WeixinJSBridgeReady', jsApiCall(wxJsApiParam, returnUrl), false);
    } else if (document.attachEvent) {
      document.attachEvent('WeixinJSBridgeReady', jsApiCall(wxJsApiParam, returnUrl));
      document.attachEvent('onWeixinJSBridgeReady', jsApiCall(wxJsApiParam, returnUrl));
    }
  } else {
    jsApiCall(wxJsApiParam, returnUrl);
  }
}

6.到这里支付就ok,
7.总结,就是两个步骤:(1)将订单信息传入后台,后台创建订单信息返回前端,(2)创建订单成功后,调用微信支付函数即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值