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 相关文章推荐
基于jQuery中对数组进行操作的方法
Apr 16 Javascript
浅谈Javascript 数组与字典
Jan 29 Javascript
JS实现的5级联动Select下拉选择框实例
Aug 17 Javascript
js 判断所选时间(或者当前时间)是否在某一时间段的实现代码
Sep 05 Javascript
基于jQuery实现放大镜特效
Oct 19 Javascript
第三章之Bootstrap 表格与按钮功能
Apr 25 Javascript
AngularJS1.X学习笔记2-数据绑定详解
Apr 01 Javascript
vue如何集成raphael.js中国地图的方法示例
Aug 15 Javascript
微信小程序url传参写变量的方法
Aug 09 Javascript
react同构实践之实现自己的同构模板
Mar 13 Javascript
适合前端Vue开发童鞋的跨平台Weex的使用详解
Oct 16 Javascript
vue打包时去掉所有的console.log
Apr 10 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自定义函数返回多个值
2006/11/26 PHP
PHP用mb_string函数库处理与windows相关中文字符及Win环境下开启PHP Mb_String方法
2015/11/11 PHP
php redis实现文章发布系统(用户投票系统)
2017/03/04 PHP
Jquery 绑定时间实现代码
2011/05/03 Javascript
javascript中的delete使用详解
2013/04/11 Javascript
jQuery输入城市查看地图使用介绍
2013/05/08 Javascript
利用jq让你的div居中的好方法分享
2013/11/21 Javascript
javascript实现漂亮的拖动层,窗口拖拽特效
2015/04/24 Javascript
AngularJS 服务详细讲解及示例代码
2016/08/17 Javascript
jQuery获取select选中的option的value值实现方法
2016/08/29 Javascript
Bootstrap列表组学习使用
2017/02/09 Javascript
tangram.js库实现js类的方式实例分析
2018/01/06 Javascript
Vue中图片Src使用变量的方法
2019/10/30 Javascript
node实现mock-plugin中间件的方法
2019/12/25 Javascript
[36:33]Ti4 循环赛第四日 附加赛NEWBEE vs Mouz
2014/07/13 DOTA
[01:45]亚洲邀请赛互动指南虚拟物品介绍
2015/01/30 DOTA
Python实现比较两个文件夹中代码变化的方法
2015/07/10 Python
浅谈numpy数组中冒号和负号的含义
2018/04/18 Python
pygame游戏之旅 添加游戏暂停功能
2018/11/21 Python
Python实现性能自动化测试竟然如此简单
2019/07/30 Python
对python中assert、isinstance的用法详解
2019/11/27 Python
在django中使用apscheduler 执行计划任务的实现方法
2020/02/11 Python
Python 找出英文单词列表(list)中最长单词链
2020/12/14 Python
css3media响应式布局实例
2016/07/08 HTML / CSS
ProBikeKit美国官网:自行车套件,跑步和铁人三项套件
2016/10/13 全球购物
Cole Haan官方网站:美国时尚潮流品牌
2017/12/06 全球购物
匡威俄罗斯官网:Converse俄罗斯
2020/05/09 全球购物
金融专业个人求职信范文
2013/11/28 职场文书
运动会入场解说词300字
2014/01/25 职场文书
办公室文员自荐书
2014/02/03 职场文书
中文专业学生自我评价范文
2014/02/06 职场文书
《赠汪伦》教学反思
2014/04/12 职场文书
竞选宣传委员演讲稿
2014/05/24 职场文书
法制主题班会教案
2015/08/13 职场文书
教师法制教育培训学习心得体会
2016/01/14 职场文书
一文搞懂Golang 时间和日期相关函数
2021/12/06 Golang