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 相关文章推荐
JQERY limittext 插件0.2版(长内容限制显示)
Aug 27 Javascript
XMLHttpRequest处理xml格式的返回数据(示例代码)
Nov 21 Javascript
Javascript函数式编程简单介绍
Oct 11 Javascript
每天一篇javascript学习小结(RegExp对象)
Nov 17 Javascript
AngularJS向后端ASP.NET API控制器上传文件
Feb 03 Javascript
基于javascript实现全屏漂浮广告
Mar 31 Javascript
angularjs指令之绑定策略(@、=、&)
Apr 13 Javascript
javascript计算对象长度的方法
Oct 25 Javascript
微信小程序如何获取openid及用户信息
Jan 26 Javascript
Angularjs中的$apply及优化使用详解
Jul 02 Javascript
解决vuex改变了state的值,但是页面没有更新的问题
Nov 12 Javascript
原生JS实现音乐播放器的示例代码
Feb 25 Javascript
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下几种删除目录的方法总结
2007/08/19 PHP
php 错误处理经验分享
2011/10/11 PHP
学习使用curl采集curl使用方法
2012/01/11 PHP
PHP获取当前日期所在星期(月份)的开始日期与结束日期(实现代码)
2013/06/18 PHP
php使用Cookie控制访问授权的方法
2015/01/21 PHP
Prototype使用指南之selector.js
2007/01/10 Javascript
js输出阴历、阳历、年份、月份、周示例代码
2014/01/29 Javascript
jquery实现标签上移、下移、置顶
2015/04/26 Javascript
js实现select下拉框菜单
2015/12/08 Javascript
JavaScript字符串常用的方法
2016/03/10 Javascript
Bootstrap每天必学之警告框插件
2016/04/26 Javascript
基于JS实现导航条之调用网页助手小精灵的方法
2016/06/17 Javascript
原生JS实现图片懒加载(lazyload)实例
2017/06/13 Javascript
前端面试知识点目录一览
2019/04/15 Javascript
VUE组件中的 Drawer 抽屉实现代码
2019/08/06 Javascript
vue 如何从单页应用改造成多页应用
2020/10/23 Javascript
[02:30]DOTA2放量测试专访海涛:呼吁保护新手玩家
2013/08/26 DOTA
[01:55]2014DOTA2国际邀请赛 BBC正赛第一天总结
2014/07/10 DOTA
[02:19]2014DOTA2国际邀请赛 专访820少年们一起去追梦吧
2014/07/14 DOTA
详解Python中find()方法的使用
2015/05/18 Python
Python pymongo模块常用操作分析
2018/09/01 Python
Python基于matplotlib画箱体图检验异常值操作示例【附xls数据文件下载】
2019/01/07 Python
使用python3构建文件传输的方法
2019/02/13 Python
关于pytorch中网络loss传播和参数更新的理解
2019/08/20 Python
Python实现图片裁剪的两种方式(Pillow和OpenCV)
2019/10/30 Python
关于Pytorch的MNIST数据集的预处理详解
2020/01/10 Python
matplotlib基础绘图命令之bar的使用方法
2020/08/13 Python
python实现网页录音效果
2020/10/26 Python
Ratchet 模态框的实现
2020/08/19 HTML / CSS
斯凯奇澳大利亚官网:SKECHERS澳大利亚
2018/03/31 全球购物
澳大利亚体育和露营装备在线/实体零售商:Find Sports
2020/06/03 全球购物
Belvilla法国:休闲度假房屋出租
2020/10/03 全球购物
2015年工会工作总结范文
2015/07/23 职场文书
学习新党章心得体会2016
2016/01/15 职场文书
《多彩的民间艺术》教学反思
2016/02/16 职场文书
Win11 22H2 2022怎么更新? 获得Win1122H22022版本升级技巧
2022/09/23 数码科技