开发微信公众号(H5)支付 WeixinJSBridge

微信支付【 JSAPI 支付】WeixinJSBridge.invoke()是微信浏览器的内置方法,只能在微信浏览器内部使用;

const that = this;
// appId,timeStamp,nonceStr,package,paySign,signType 数据均从后端获取(我后台引用 IJPay-WxPay 插件工具)
// 调用支付传递的参数注意区分大小写
function onBridgeReady(){
   WeixinJSBridge.invoke(
      'getBrandWCPayRequest', {
         "appId":"", // 公众号ID,由商户传入     
         "timeStamp":"", // 时间戳,自1970年以来的秒数     
         "nonceStr":"", // 随机串     
         "package":"prepay_id=xxx",     
         "signType":"", // 微信签名方式:     
         "paySign":"" // 微信签名 
      },
      function(res){
          if(res.err_msg == "get_brand_wcpay_request:ok" ){
              // 使用以上方式判断前端返回,微信团队郑重提示:
              //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。
          }  else if (res.err_msg === "get_brand_wcpay_request:cancel") {
              // 支付过程中用户取消
          } else if (res.err_msg === "get_brand_wcpay_request:fail") {
              // 支付失败
          } else {
              /* *
			     * 其它
			     * 1、请检查预支付会话标识prepay_id是否已失效
			     * 2、请求的appid与下单接口的appid是否一致
                 * 其它报错例如:{"err_msg":"system:access_denied"} 等
			   * */
          }
       }
    ); 
}
// 判断是否在微信环境中
if (typeof WeixinJSBridge == "undefined"){
   if( document.addEventListener ){
       document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);
   }else if (document.attachEvent){
       document.attachEvent('WeixinJSBridgeReady', onBridgeReady); 
       document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);
   }
}else{
   onBridgeReady();
}

微信公众平台 - 微信内置浏览器 JSAPI 唤起支付报错? | 微信开放社区 (qq.com)  JSAPI支付,JS-SDK 返回错误:【chooseWXpay: permission denied】微信内置浏览器 WeixinJSBridge.invoke(‘xxx‘) API 报错:system:access_denied 这个问题有小程序进入H5引发,小程序不支持webview发起支付

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值