微信支付之JSAPI开发-第二篇:业务流程详解与方案设计

微信支付流程

流程:

支付

上图的网址为:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_4

如上图所示,微信网页支付的具体流程大致分为三个部分,最重要的是第一和第二部分:

  1. 第一部分:用户进入网页
    • 用户点击消息、链接或者扫描二维码,进入商品界面(即触发网页的window.onload事件的时候)。
    • 网页产生支付请求至商户服务器,支付服务器先产生商户订单,然后调用 统一下单API,向微信服务器发送请求。
    • 商户服务器接收到微信服务器对统一下单API的响应后,提取出参数prepay_id,并根据算法(后面会提到)生成支付签名,然后将prepay_id和支付签名作为上一步支付请求的响应数据返回给客户端,客户端 缓存此数据
  2. 第二部分:用户发起请求,服务器响应
    • 用户在商品界面中点击支付按钮后,根据第一部分取到的数据和商品数据调用jsapi接口(至微信服务器)请求支付,微信支付服务器对请求进行验证并响应,这个过程中,微信客户端显示“微信支付”的动画。
    • 如果上一步的请求验证通过,此时微信客户端会弹出密码输入对话框,让用户输入密码。
    • 用户输入密码点击支付后,微信客户端提交支付授权。
    • 微信客户端对支付授权进行验证,并将结果 同时发送 至用户客户端和商户服务器。其中微信服务器发送至商户服务器的通知url在第一部分的统一下单接口中由商户指定。
    • 商户服务器对上一步收到的结果进行处理,并响应。客户端也会收到微信支付结果的模板消息。

注意: 第二部分和商户的服务器没有任何交互。

  1. 第三部分
    • 微信跳转回商户的H5页面。
    • 商户网页调用请求查询订单结果。

具体的实现方案

上面的介绍详细解释了微信支付的流程,那么根据此流程,我们就可以分别对微信网页支付设计前端和后端的实现方案。

我们可以看到,上面的支付流程中有一点不是很合理的地方:就是每进入一次网页就请求一次支付接口,产生一个订单。因为很多时候,用户打开网页并不会点击购买产生实质的支付请求。这样会无故消耗不少服务器资源,特别是对于高并发网站来说。

对此我的改进方案是:在用户点击相关的产生实质支付的按钮时,才向商户后台发送支付,再调统一下单接口,返回prepy_id和签名,然后利用这个数据进行上面的第二部分,请求微信支付。这样做的好处是可以减少无效请求,但是坏处是两次请求的时间可能会较长,特别是第一个向商户后台下订单的请求,因为这个还需要调微信支付的服务,可能整个请求的响应会超过1s,慢的甚至2~3s,这会严重影响用户体验。而且此时,一般需要在前端显示一个“正在请求支付”的加载动画,不然几秒没响应用户会以为没效果再点击造成重复下单。

我们按照上面描述的改进方案进行前端和后端支付业务流程的设计。

微信网页支付前端流程

在第一节的图中忽略了一点,使用微信JSAPI支付的网页,必须在支付前使用微信JSAPI的config接口注入权限验证配置,这一步一般放在网页加载后,即window.onload()函数中来执行。具体内容参考:微信网页开发说明

前端的流程如下:

  1. 在页面中引入JS文件,网址为: http://res.wx.qq.com/open/js/jweixin-1.0.0.js
    ,在需要支付的页面中根据上面提到的注入权限验证配置(在页面的window.onload()函数编写wx.config()函数),权限配置验证中需要向商户服务器请求签名,后面会提到。
  2. 编写支付按钮的点击事件逻辑,函数中包括:
    • 向商户后台发送下单请求,返回的数据包括统一下单请求结果,(如成功),还有prepay_id和生成的支付签名。签名算法说明
    • 如果上一步成功,调用WeixinJSBridge.invoke函数调起支付,并编写支付成功和失败的回调函数。

微信网页支付后端流程

微信支付主要的逻辑在后端,后端的逻辑如下:

  1. 用户进入网页时,前端发送权限注入需要的签名请求,进行签名,并返回签名数据。签名算法 的附录一部分,涉及到请求的access_token是:网页授权access_token
  2. 用户点击支付,产生支付请求:
    • 获取支付金额等信息,先调用相关逻辑产生商户的订单,再按照统一下单API规定生成所需的数据,发送统一下单请求,获得响应。
    • 处理上一步的响应,如果成功,根据说明链接产生签名字符串,响应上一步的请求。

      为了前端处理方便,这一步可以将支付请求所需的所有参数都生成然后返回。

  3. 响应微信服务器发送支付结果:
    对第二步统一下单API中指定的notify_url添加支付结果处理逻辑,根据支付结果通知所述,返回指定信息,此接口要有处理重复通知的能力,具体详见前面的链接

其他

下面几篇文章将展示实现微信网页支付逻辑的前端和后端(基于java web框架spring mvc)的示例代码。

如有错误和疑惑之处请在评论区指出,谢谢。

转载于:https://www.cnblogs.com/xyb930826/p/6008993.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信JSApi支付是指在微信公众号或小程序内使用JSAPI调起微信支付功能,实现用户在微信内完成付款的一种方式。以下是常见的问题及解决方法: 1. 支付时提示“商户订单号重复” 解决方法:修改商户订单号,确保每笔订单的商户订单号唯一。 2. 支付时提示“支付金额与订单金额不一致” 解决方法:检查订单金额和实际支付金额是否相同,确保订单金额与实际支付金额一致。 3. 支付时提示“支付失败,请稍后再试” 解决方法:检查支付参数是否正确,确保支付参数的完整性和准确性。 4. 支付时提示“当前用户未授权,请先授权登录” 解决方法:用户需要先授权登录,获取用户信息后才能进行支付操作。 5. 支付时提示“当前用户未关注公众号” 解决方法:用户需要先关注公众号,才能进行支付操作。 6. 支付时提示“商户号与appid不匹配” 解决方法:检查商户号和appid是否对应,确保商户号和appid的匹配性。 7. 支付时提示“订单已关闭” 解决方法:订单可能已经被关闭或者已经完成支付,需要重新下单。 8. 支付时提示“系统繁忙,请稍后再试” 解决方法:服务器可能正在维护或者出现故障,需要等待一段时间后再尝试支付。 以上是微信JSApi支付常见问题及解决方法,如果以上方法无法解决问题,可以联系微信支付客服进行咨询。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值