关于微信公众号、小程序跨号支付的坑

这段时间因为业务需求,需要将部分业务转移到微信公众号上,并提供有偿付费使用,这其中就要涉及到微信支付。虽然微信相关文档齐全,但是总体是依据普通流程来描述的,如果与普通流程稍稍不一样,就会出现无资料可查的境地。而由于我公司已经有公众号申请了微信支付,所以我们不用在当前的业务公众号/小程序中再次申请微信支付,想利用微信提供的跨公众号支付方式,使用一个统一的微信商户号进行支付。本来预计两天开发完微信支付,结果这其中出现了好多意外,导致超出预期,多花了两天在踩了好几个坑后(当然也可能自己理解能力有限),终于搞定了微信公众号/小程序利用其它公众号绑定的商户进行微信支付。

关于认证的问题这里就不说了,基本上按微信的文档进行认证或绑定就行了。基本上所有的问题都集中在“统一下单”时的参数上,下面我就将这其中有几个容易误解的地方列出来供大家参考:

一、微信公众号支付

假如我们要开发的微信公众号为A,而要利用已有支付功能的公众号为B。

1、公众账号ID appid:此处应填入B公众号的appid;

2、商户号 mch_id:此处应填入B公众号下所属微信支付商户的商户号id;

3、用户标识 openid:此处应填入当前微信用户在B公众号下的openId。

容易出现问题的地方是第3处,大家有可能填入的是微信用户在A公众号下的openId,结果就会出现“appid and openid not match"的问题。所在需要在统一下单前,进行B公众号的静默授权调用:

参考链接(请在微信客户端中打开此链接体验):

scope为snsapi_base

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wx520c15f417810387&redirect_uri=https%3A%2F%2Fchong.qq.com%2Fphp%2Findex.php%3Fd%3D%26c%3DwxAdapter%26m%3DmobileDeal%26showwxpaytitle%3D1%26vb2ctag%3D4_2030_5_1194_60&response_type=code&scope=snsapi_base&state=123#wechat_redirect

注意在snsapi_base为scope发起的网页授权,是用来获取进入页面的用户的openid的,并且是静默授权并自动跳转到回调页的,用户感知的就是直接进入了回调页(往往是业务页面),在我们的业务回调接口中即可获取的在B公众号下的openId,并填入统一下单参数即可。关于授权方式可以参照微信的开发文档(https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421140842)。

二、小程序支付

假如我们要开发的微信小程序为A,而要利用已有支付功能的公众号为B。A已经利用M-A授权获得了B公众号下的微信商户的支付授权。那统一下单时,参数应该这样:

1、小程序ID appid:此处应填入A小程序的appid;

2、商户号 mch_id:此处应填入B公众号下所属微信支付商户的商户号id;

3、用户标识 openid:此处应填入当前微信用户在A小程序下的openId。

微信开发文档中,对于小程序在支付前,统一下单参数中的openid是这样描述的:

type=JSAPI,此参数必传,用户在商户appid下的唯一标识。openid如何获取,可参考【获取openid】。

这句话给了我很大的误解,一开始我以为在小程序下,也要像微信公众号跨号支付那样,静默去获取B公众号下的openId。于是,我们反复尝试在小程序如何实现获取B公众号下的openId,但是都无果而终。翻了网上的资料,也没有人提到在M-A授权模式下如何填写此open。最后,只能以死马当活马医的精神,将小程序自己下的openId填入,结果一次成功。

期间也打过微信客服电话,客服表示没有提供电话技术支持,请多阅读微信开发文档。我只想说微信文档是给什么都绑定在一个公众号或一个小程序中的人看的,既然你提供了第三方授权的支付方式,就应该在文档中多描述几句,方便客户开发时少走弯路。当然,也可能是我多虑了,我们这么不会动活脑筋的人是少数:)...

仅以此供有可能和我一样正在困惑的人参考吧。

你可能感兴趣的:(关于微信公众号、小程序跨号支付的坑)