iOS 收集专题

iOS实现微信外部H5支付完成后返回原APP(多APP也可实现)

2018-10-25  本文已影响73人  SmallHer

文末有原文链接

看到微信最近放开了微信H5支付,公司决定把H5集成到多款APP上。下面记录下了开发过程。

由于是微信新推出的支付方式,在网上搜索到的相关资料并不多,其中有一篇文章(点此跳转)对我的整个开发过程起到了很大帮助,在此表示感谢。

首先去微信商户后台去申请开通H5支付。

微信审核通过需要3至5个工作日。

我们假设支付域名填写的  aaa.cn,注意是顶级域名,不是二级或三级的子域名。

服务器端通过统一下单接口从微信拿到支付跳转链接(https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb?prepay_id=wx20180115115052bedf091fba0369993002&package=2975002856),称为mweb_url,有效期为5分钟。

由于这里是APP调起支付,不是网页H5发起支付,所以这里mweb_url值不需要再拼接上redirect_url参数。

然后移动端进行请求mweb_url,就会调起微信APP支付。

可能会出现以下问题:

“出现商家参数格式有误,请联系商家解决”

说明在请求mweb_url时referer为空导致,设置上就可以,这里我们设置最先在商户后台注册的aaa.cn的一个多级子域名,比如:b.aaa.cn。

如果不是设置商户后台注册的顶级域名的多级子域名,比如:b.ccc.cn。

就会出现“商家存在未配置的参数,请联系商家解决”异常。

那就把ccc.cn注册到商户后台就可以解决了。

到目前为止,你就可能正常支付了,但支付成功后,并不能正常跳回原APP,严重影响了用户体验。

解决方案:把referer设置成:b.aaa.cn://,scheme设置成:b.aaa.cn就可以直接返回APP了。

如是你只有一款APP使用此支付方式,那就可以到此为止了。

如果你有两款以上APP(比如X1,X2,X3),并都把referer设置成:b.aaa.cn://,scheme设置成:b.aaa.cn。

用户只安装了其中一款APP(X1),此时支付能够成功,并能转回原APP,一点问题没有。如果同时安装了(X1,X2),就会发现支付能够成功,但成功后页面静止,不能跳回原APP了,也严重影响了用户体验。

想到的第一个解决方案就是更改referer与scheme。

通过测试发现不起作用。在网上搜索了很久也没有找到解决方案,感觉只能妥协了,牺牲点用户体验,让用户点击左上角返回原APP。

突然灵光一闪,微信商户后台即然让我们注册顶级域名,那是不是只要把referer与scheme设置成注册的顶级域名的多级子域名就可以了呢,如下:

通过测试,完美运行。理论上这个解决方案可以支持无数个APP,也同时解决了微信开放平台APP支付的限制个数。

转自冬虫吃夏草的博客iOS实现微信外部H5支付完成后返回原APP(多APP也可实现)

参考链接:

iOS 解决微信h5支付无法直接返回APP的问题

iOS支付宝H5无法返回APP解决方案

iOS微信H5支付无法返回APP解决方案

       

上一篇下一篇

猜你喜欢

热点阅读