iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在Html5中实现微信支付
  • 443
分享到

怎么在Html5中实现微信支付

2023-06-09 21:06:14 443人浏览 安东尼
摘要

本篇文章为大家展示了怎么在HTML5中实现微信支付,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。爬坑之路爬坑一:单页SPA和后端路由的问题这个我已经单独做总结:https://www.yisu.co

本篇文章为大家展示了怎么在HTML5中实现微信支付,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

爬坑之路

爬坑一:单页SPA和后端路由的问题

这个我已经单独做总结https://www.yisu.com/article/144341.htm

爬坑二:安卓大概率调起微信支付失败(引入微信的js-sdk包失败)

在微信的官方文档中:Https://pay.weixin.qq.com/wiki/doc/api/jsapi.PHP?chapter=7_7&index=6

有这样的一个DEMO:

function onBridgeReady(){   WeixinJSBridge.invoke(      'getBrandWCPayRequest', {         "appId":"wx2421b1c4370ec43b",     //公众号名称,由商户传入              "timeStamp":"1395712654",         //时间戳,自1970年以来的秒数              "nonceStr":"e61463f8efa94090b1f366cccfbbb444", //随机串              "package":"prepay_id=u802345jgfjsdfgsdg888",              "signType":"MD5",         //微信签名方式:              "paySign":"70EA570631E4BB79628FBCA90534C63FF7FADD89" //微信签名       },      function(res){      if(res.err_msg == "get_brand_wcpay_request:ok" ){      // 使用以上方式判断前端返回,微信团队郑重提示:            //res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。      }    }); }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();}

在后端同事授权成功后,在活动页面页面引入这段代码,开开心心,build 提交 测试 嗯苹果没问题,安卓好像没问题,然鹅安卓有时候调不起支付,开始以为是微信版本的原因,等等其他,但是,调起成功的概率也太TM低了,10次才能调起1次,得,肯定是代码原因了。改吧。

解决思路:

开微信开发工具,打log,最后发现在这一步时候if (typeof WeixinJSBridge == "undefined")

iOS能够调起微信浏览器的js-sdk

安卓大部分都走到undefined里面去了

这里其实我也不太清楚原因。个人感觉是微信安卓的内置浏览器版本和这个 WeixinJSBridge 方法的问题。(希望有大神能够解答一下)

既然js-sdk 调不起,那就手动引入配置吧 //所以有时候偷懒反而更加麻烦,吸取教训

if (typeof WeixinJSBridge == "undefined"){    console.log( WeixinJSBridge);   if( document.addEventListener ){       document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);   }else if (document.attachEvent){       document.attachEvent('WeixinJSBridgeReady', onBridgeReady);        document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);   }}else{   onBridgeReady();}

Vue引入微信js-sdk包

npm i -S weixin-js-sdk

在需要引入的页面引入模块

import wx from 'weixin-js-sdk'

配置(参考微信官方文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115):

wx.config({    debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。    appId: '', // 必填,公众号的唯一标识    timestamp: , // 必填,生成签名的时间戳    nonceStr: '', // 必填,生成签名的随机串    signature: '',// 必填,签名    jsApiList: [] // 必填,需要使用的JS接口列表 比如我要调用支付接口 那么就是 [chooseWXPay]});

这里timestamp是小写 s 是小写,数据类型是 int 类型

接下来既然配置成功了,那就继续看官方文档

在官方文档是这么说的,有个ready的方法,在config验证成功之后,把接口放在里面确保执行。

wx.ready(function(){    // config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。});

ready里面的引入参数(注意数据类型,和后端同事好好配合- -)

wx.chooseWXPay({timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符nonceStr: '', // 支付签名随机串,不长于 32 位package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'paySign: '', // 支付签名success: function (res) {// 支付成功后的回调函数}});

附上本人的demo

在ready里面使用Vue data中的数据,一不小心掉到this指向的坑,如果不加bind,wx.chooseWXPay里面的参数是拿不到从后端请求回来的数据的,这里的this并不是指向VueComponent,自然无法获取请求后我赋值给this.wx_config这个数组对象的数据。

getConfig(){            wx.config({                debug: this.wx_config.debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。                appId: this.wx_config.appId, // 必填,公众号的唯一标识                timestamp: this.wx_config.timestamp, // 必填,生成签名的时间戳                nonceStr: this.wx_config.nonceStr, // 必填,生成签名的随机串                signature:this.wx_config.signature,// 必填,签名                jsApiList: this.wx_config.jsApiList // 必填,需要使用的JS接口列表            });            //微信支付            wx.ready(function() {                // console.log(this.jsApiCall());                wx.chooseWXPay({                    timestamp: this.wechat_code.timestamp,                    nonceStr:this.wechat_code.nonceStr,                    package: this.wechat_code.package,                    signType: this.wechat_code.signType,                    paySign: this.wechat_code.paySign,                    success: function () {                        // 支付成功后的回调函数                        alert("支付成功");                        window.location.href = "/hd/becomevip";                    },                    cancel: function() {                        alert("支付失败");                    }                });            }.bind(this));        },

上述内容就是怎么在html5中实现微信支付,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 怎么在Html5中实现微信支付

本文链接: https://www.lsjlt.com/news/257907.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在Html5中实现微信支付
    本篇文章为大家展示了怎么在Html5中实现微信支付,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。爬坑之路爬坑一:单页SPA和后端路由的问题这个我已经单独做总结:https://www.yisu.co...
    99+
    2023-06-09
  • Android中怎么实现微信支付功能
    Android中怎么实现微信支付功能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 去微信开放平台申请微信支付服务,绑定自己的应用这里具体不多讲,但是一定要申请完成,将会得到是...
    99+
    2023-05-31
    android
  • PHP实现微信支付流程(Native支付)
    最近项目需要做微信支付的功能,想着把流程以及遇到的坑记录下来 1.到微信商户平台中去开通Native支付(产品中心-Native支付-申请开通) 2.微信商户平台中下载证书以及设置api密钥(账户中心-api安全),查看指引中很详细的说...
    99+
    2023-08-31
    php 微信 Powered by 金山文档
  • vue项目中的支付功能实现(微信支付和支付宝支付)
    目录项目中常见的支付方式    支付宝支付微信支付项目中常见的支付方式     支付宝支付  &nbs...
    99+
    2022-11-12
  • 怎么用Java也实现微信和支付宝支付功能
    这篇文章主要介绍“怎么用Java也实现微信和支付宝支付功能”,在日常操作中,相信很多人在怎么用Java也实现微信和支付宝支付功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2022-10-19
  • PHP 实现微信支付 JSAPI
    目录 一、首先我们来填个坑 1:支付验签失败 二、代码示例 1.请求参数配置 2.统一下单API 3.MakeSign 签名 4.ToXml 数组参数转xml 5.postXmlCurl 发送请求 6.FromXml 结果xml参数转数组 ...
    99+
    2023-09-12
    php 微信 微信公众平台
  • 怎么用PHP实现支付宝和微信扫码在线支付的功能
    本篇内容介绍了“怎么用PHP实现支付宝和微信扫码在线支付的功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2022-10-18
  • 微信小程序中如何实现微信支付
    微信支付是微信公众平台提供的一种在线支付服务,可以为用户提供快速、方便、安全的支付体验。而在微信小程序中实现微信支付,则可以为应用程序提供更多的功能和服务,提高用户体验和商业价值。因此,在本文中,我们将介绍如何在微信小程序中实现微信支付。 ...
    99+
    2023-08-16
    微信小程序 微信 小程序 前端 javascript
  • php实现微信支付功能
    一、生成预支付订单并获取预支付ID(prepay_id): ...
    99+
    2023-09-11
    php
  • 微信小程序支付功能怎么实现
    实现微信小程序支付功能,需要以下步骤:1. 首先,在微信公众平台申请开通支付功能,并获取到支付相关的配置信息,包括 appID、商户...
    99+
    2023-08-16
    微信小程序
  • springboot中怎么对接微信支付
    springboot中怎么对接微信支付,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。对接的完整流程如下首先是配置gzh.appid=公众号appidwxPay.mchId=...
    99+
    2023-06-20
  • iOS实现H5支付(微信、支付宝)原生封装
    前言 支付分APP支付、H5支付、扫码支付等。app支付一般在app中使用,并且需要集成相应的支付SDK,H5支付多用于网页。如果你的APP不想集成支付SDK,又想实现支付功能,你...
    99+
    2022-06-05
    iOS H5支付 微信 支付宝
  • 如何进行vue项目中的支付功能实现(微信支付和支付宝支付)
    如何进行vue项目中的支付功能实现(微信支付和支付宝支付),针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。项目中常见的支付方式    支付宝支付...
    99+
    2023-06-22
  • 在PHP中实现微信支付的发起和查询
    随着微信支付的普及,越来越多的网站需要集成微信支付功能。在这篇文章中,我们将讨论如何在PHP中实现微信支付的发起和查询。调用统一下单API在PHP中发起微信支付,第一步是调用微信支付的统一下单API来生成预支付订单。该API需要传递一些必要...
    99+
    2023-05-14
    PHP 微信支付 发起和查询
  • PHP 实现微信Native扫码支付
    目录 一、安装微信SDK 二、准备请求资料 三、引入和定义 四、Native下单 五、Native调起支付 六、Native异步通知 一、安装微信SDK composer require wechatpay/wech...
    99+
    2023-09-25
    开发语言 php 微信 thinkphp
  • Python3微信支付(小程序支付)V3接口的实现
    起因: 因公司项目需要网上充值功能,从而对接微信支付,目前也只对接了微信支付的小程序支付功能,在网上找到的都是对接微信支付V2版本接口,与我所对接的接口版本不一致,无法使用,特此记录...
    99+
    2023-01-17
    Python3 微信支付V3接口 Python3 微信支付
  • php实现微信jsapi支付(v2版本)
    统一下单 public function unifiedOrder($product_type = 1, $openid = '', $phone = '') { ...
    99+
    2023-10-09
    php 微信 开发语言
  • PHP实现 APP端微信支付功能
    一丶 PHP后台生成预支付交易单,返回正确的预支付交易回话标识后 调起支付,根据文档拼接微信需要的参数,这里将需要的几个方法进行示例; 传输给微信的参数要组装成xml格式发送,传如参数数组! publ...
    99+
    2023-10-18
    php 微信 android
  • SpringBoot如何实现整合微信支付
    这篇文章将为大家详细讲解有关SpringBoot如何实现整合微信支付,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.准备工作1.1 数据库表这里涉及微信支付一共两个表:订单表支付记录表1.2 实体类数据...
    99+
    2023-06-22
  • Java 实现微信支付详细教程
    摘要:最近的一个项目中涉及到了支付业务,其中用到了微信支付和支付宝支付,在做的过程中也遇到些问题,所以现在总结梳理一下,分享给有需要的人,也为自己以后回顾留个思路。 一、微信支付接入准备工作: 首先,微信支付,只支持企业用户,个人用户是不能...
    99+
    2023-08-19
    java 微信 开发语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作