vue项目前端微信JSAPI与外部H5支付相关实现过程及常见问题


Posted in Javascript onApril 14, 2020

web端的微信支付可分为JSAPI与H5

JSAPI使用场景为微信内部,而H5支付则是使用在非微信下的外部浏览器。

1.JSAPI

在微信内部可以直接唤起微信浏览器的内置对象 WeixinJSBridge
废话不多说直接上代码:

// 调用后端接口拿到JSAPI支付所需参数,我在beforeRouteEnter的时候调用。
api.apply.jsApiPay(obj).then(res => {
     if (res.data.code === '0000') {
      vm.params = res.data.bean
     } else {
      alert('微信支付调起失败!')
     }
    }).catch(err => {
     alert(err)
    })

// 点击支付时候调用
if (typeof WeixinJSBridge === 'undefined') {
    if (document.addEventListener) {
     document.addEventListener('WeixinJSBridgeReady', this.onBridgeReady(this.params), false)
    } else if (document.attachEvent) {
     document.attachEvent('WeixinJSBridgeReady', this.onBridgeReady(this.params))
     document.attachEvent('onWeixinJSBridgeReady', this.onBridgeReady(this.params))
    }
   } else {
    this.onBridgeReady(this.params)
   }


onBridgeReady (params) {
   const that = this
   WeixinJSBridge.invoke(
    'getBrandWCPayRequest',
    {
     appId: params.appId, // 公众号名称,由商户传入
     timeStamp: params.timeStamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
     nonceStr: params.nonceStr, // 支付签名随机串,不长于 32 位
     package: params.prepay_id, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
     signType: params.signType, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
     paySign: params.paySign // 支付签名
    },
    function (res) {
     if (res.err_msg === 'get_brand_wcpay_request:ok') {
      that.queryOrder() // 这里是查询订单是否支付完成,然后执行成功和失败的业务逻辑
     } else if (res.err_msg === 'get_brand_wcpay_request:fail') {
      alert('支付失败!')
     }
    }
   )
  },

在微信支付的回调函数中,当res.err_msg 为

get_brand_wcpay_request:ok 时,支付状态不一定准确,因此需要调用后端的查询订单接口,查询是否支付完成,然后再执行相应的逻辑。

2、H5支付

h5相对简单,前端只需要跳转到后端返回的链接即可

api.apply.h5Pay({
      title: ''
      orderNum: '',
      expireMinute: 10,
      redirectUrl: `${window.location.origin}/pay/card?orderId=${vm.orderId}`
     }).then(res => {
      vm.h5PayUrl = res.data.bean
      // 查询订单
     }).catch(err => {
      alert(err)
     })

第一步,请求后端接口,需要传支付的标题,订单号,支付时间,重定向链接。

第二部,们只需要点击支付按钮时候跳转至后端返回链接即可。

window.location.href = this.h5PayUrl

需要注意的是H5支付查询订单需要用户去手动触发,因此需要增加一个确定订单的弹层。如图:

vue项目前端微信JSAPI与外部H5支付相关实现过程及常见问题

查询订单是否支付成功与JSAPI一致~

到此这篇关于vue项目前端微信JSAPI与外部H5支付相关实现过程及常见问题的文章就介绍到这了,更多相关vue项目前端微信JSAPI与外部H5支付相关实现过程及常见问题内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
javascript对数组的常用操作代码 数组方法总汇
Jan 27 Javascript
自定义一个jquery插件[鼠标悬浮时候 出现说明label]
Jun 27 Javascript
用JS判断IE版本的代码 超管用!
Aug 09 Javascript
包含中国城市的javascript对象实例
Aug 03 Javascript
浅谈jquery设置和获得checkbox选中的问题
Aug 19 Javascript
javascript 判断页面访问方式电脑或者移动端
Sep 19 Javascript
解决html-jquery/js引用外部图片时遇到看不了或出现403的问题
Sep 22 jQuery
vue跨域解决方法
Oct 15 Javascript
原生JavaScript实现的简单放大镜效果示例
Feb 07 Javascript
iview同时验证多个表单问题总结
Sep 29 Javascript
JS函数内部属性之arguments和this实例解析
Oct 07 Javascript
vue 数据双向绑定的实现方法
Mar 04 Vue.js
JavaScript代码压缩工具UglifyJS和Google Closure Compiler的基本用法
Apr 13 #Javascript
JS实现表单中点击小眼睛显示隐藏密码框中的密码
Apr 13 #Javascript
vue cli3适配所有端方案的实现
Apr 13 #Javascript
RxJS在TypeScript中的简单使用详解
Apr 13 #Javascript
JS错误处理与调试操作实例分析
Apr 13 #Javascript
JS正则表达式常见函数与用法小结
Apr 13 #Javascript
javascript设计模式 ? 桥接模式原理与应用实例分析
Apr 13 #Javascript
You might like
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
php中yii框架实例用法
2020/12/22 PHP
你必须知道的JavaScript 变量命名规则详解
2013/05/07 Javascript
window.opener用法和用途实例介绍
2013/08/19 Javascript
jquery 按键盘上的enter事件
2014/05/11 Javascript
node.js中的fs.symlinkSync方法使用说明
2014/12/15 Javascript
JavaScript中Cookies的相关使用教程
2015/06/04 Javascript
jquery实现带渐变淡入淡出并向右依次展开的多级菜单效果实例
2015/08/22 Javascript
JS实现网页Div层Clone拖拽效果
2015/09/26 Javascript
JavaScript仿微博输入框效果(案例分析)
2016/12/06 Javascript
在 React、Vue项目中使用SVG的方法
2018/02/09 Javascript
vue中keep-alive的用法及问题描述
2018/05/15 Javascript
JavaScript中toLocaleString()和toString()的区别实例分析
2018/08/14 Javascript
微信小程序自定义组件封装及父子间组件传值的方法
2018/08/28 Javascript
JS实现图片拖拽交换效果
2018/11/30 Javascript
实用Javascript调试技巧分享(小结)
2019/06/18 Javascript
微信小程序可滑动月日历组件使用详解
2019/10/21 Javascript
[42:23]完美世界DOTA2联赛PWL S3 Forest vs Rebirth 第二场 12.10
2020/12/13 DOTA
Tensorflow 查看变量的值方法
2018/06/14 Python
基于django channel实现websocket的聊天室的方法示例
2019/04/11 Python
Python3合并两个有序数组代码实例
2020/08/11 Python
python中round函数保留两位小数的方法
2020/12/04 Python
一款利用css3的鼠标经过动画显示详情特效的实例教程
2014/12/29 HTML / CSS
浙江文明网签名寄语
2014/01/18 职场文书
财务主管岗位职责
2014/02/28 职场文书
缓刑人员思想汇报
2014/10/11 职场文书
党的群众路线教育实践活动个人对照检查材料(四风)
2014/11/05 职场文书
党员思想汇报材料
2014/12/19 职场文书
2015年三万活动总结
2015/03/25 职场文书
学雷锋献爱心活动总结
2015/05/11 职场文书
预备党员群众意见
2015/06/01 职场文书
初中信息技术教学反思
2016/02/16 职场文书
Nginx解决前端访问资源跨域问题的方法详解
2021/03/31 Servers
能用CSS实现的就不要麻烦JavaScript了
2021/10/05 HTML / CSS
mysql5.7的安装及Navicate长久免费使用的实现过程
2021/11/17 MySQL
vue如何使用模拟的json数据查看效果
2022/03/31 Vue.js