好了,不 BB 了,今天跟大家分享一下聚合收款码的支付原理,这也是我这大半年来一直在做的项目。
微信/支付宝收款码大家应该不会陌生,线下小微商户收款大多使用这个,就比如下图。
这种收款方式很方便,微信、支付宝后台申请开通,然后还可以免费申请相关物料。
不过这种方式用户体验其实不是很好,之前有好几次拿出支付宝,却扫了微信支付码。
另外,这种个人的收款码通常还有单日收款的上限,比如支付宝单日上限 500元。
有了需求,自然会有聪明人人想到解决方案,于是有了聚合收款码产品解决方案,如下图。
一个收款码,支持多种客户端,主流是微信、支付宝,现在常见还会支持银联,QQ 等。
用户选择任一支持的客户端扫码,都能完成支付,再也不用纠结扫错码的尴尬。
有没有很神奇?其实底层原理很简单,看完你就明白了,下面就让小黑哥带你解密聚合收款码的底层原理。
聚合收款码底层支付其实还是离不开微信、支付宝支持的支付方式,所以我们先从微信支付宝渠道出发,简单介绍这个过程将会使用的支付方式。
上篇文章,我们以支付宝为例来介绍,这次我们就以微信支付为例。
打开微信支付官网,可以看到很多支付方式。
其中付款码支付在前两篇文章完整介绍过,这里不再介绍,感兴趣的小伙伴可以看下下面这两篇文章。
首先我们介绍一下「微信Native支付」,引用微信官网的解释:
❝Native支付是商户系统按微信支付协议生成支付二维码,用户再用微信“扫一扫”完成支付的模式。该模式适用于PC网站支付、实体店单品或订单支付、媒体广告支付等场景。
❞
简单来讲就是商户后台调用微信支付接口,微信返回预支付交易的链接,格式如下:
weixin://wxpay/bizpayurl?sr=123456
然后商户将其转为二维码,提供给客户使用微信扫码支付。
来自微信支官网
这种支付方式可以应用在 PC 网站购物场景,比如说英雄联盟官网购买相关游戏道具:
既然「微信Native支付」最后可以变成二维码完成支付,那么聚合收款码是不是可以采用「微信Native支付」这种支付方式呢?
答案是可以,但是不适合,产品体验不太好。
最好使用微信支付另外一种支付产品「JSAPI 支付」。
至于原因,不要急,接下去看就会明白。
「JSAPI 支付」,又被称为公众号支付,名词解释引用一下官网介绍:
❝JSAPI 支付是用户在微信中打开商户的 H5 页面,商户在 H5 页面通过调用微信支付提供的 JSAPI 接口调起微信支付模块完成支付。
❞
具体业务流程如下:
来自微信支官网
日常生活中,很多应用场景使用这种支付方式,比如说:极客时间公众号上购买课程
这种支付方式相对于「微信Native支付」,比较麻烦,还需要使用微信公众号登录授权功能,以此获取用户的 openid。
另外当我们调用「微信 JSAPI」 后台接口,拿到微信返回的相关参数之后,我们还需要使用「微信的 JSSDK」,这样才能唤起微信支付。
了解完聚合支付的所需要的底层支付方式,下面我们来了解一下聚合收款码的核心原理。
聚合收款码业务流程如下:
聚合收款码
第一步用户使用微信/支付宝 APP 扫码之后,将会打开一个收银台页面。
这个收银台页面可以自适应,不同 APP 显示不同的样式,比如支付宝打开收银台显示支付宝的 logo,微信打开就会显示微信的 logo。
第二步用户在收银台输入金额,点击支付之后将会唤起 APP 的支付弹窗。
好了,观察这个流程,我们可以发现扫码之后,后台应用需要识别出当前 APP 到底是微信还是支付宝。
那如何判断当前使用的 APP 呢?
其实这个原理很简单,在支付宝/微信打开一个链接,实际将会使用内置的浏览器发起了 HTTP 请求,而 HTTP 的请求头将会携带 「User-Agent(UA)」,用来标识用户代理软件的应用类型、操作系统、软件开发商以及版本号。
微信/支付宝中浏览器发起 HTTP 请求,携带的 「User-Agent」 分别为:
支付宝
UCBrowser/11.5.0.939 UCBS/2.10.1.6 Mobile Safari/537.36 AliApp(AP/10.0.15.051805) AlipayClient/10.0.15.051805 Language/zh-Hans
微信
MQQBrowser/6.2 TBS 043220 Safari/537.36 MicroMessenger/6.5.8.1060 NetType/4G Language/zh_CN
这里需要注意了,不同型号的手机,不同的版本 APP,「User-Agent」 不一定会一样,其实我们只需要判断是否包含某些关键字即可,比如说只要 「User-Agent」 包含 「MicroMessenger」 就是微信,包含 「AlipayClient」 就是支付宝。
下面使用 Java 代码为例:
String userAgent = request.getHeader("user-agent");
if (Objects.equals(userAgent, "AlipayClient")) {
// 支付宝
} else if (Objects.equals(userAgent, "MicroMessenger")) {
// 微信
}
这个问题解决之后,后面的流程就很简单了,只要调用微信/支付宝的 「JSAPI 支付」接口,拿到相关参数之后,唤起支付。
❝准确来讲,支付宝那边 JSAPI 支付官方名称为支付宝生活号支付。
❞
这里解释一下上面的问题,为什么聚合收款码不能使用「微信Native支付」呢?
主要是因为「微信Native支付」接口返回是一个微信自定义 schema 协议,只能通过微信扫码打开,唤起支付。
如何聚合收款码使用「微信Native支付」,收银台提交金额之后,需要将微信返回交易链接转成二维显示在页面,然后用户使用微信内置识别二维码功能唤起支付。
这样一来比较影响产品体验,降低支付的成功率。
支付宝也有类似「微信Native支付」支付接口-「当面付扫码支付」,成功调用之后也会返回支付链接。
那这里可以提大家提个小问题,聚合收款码是否可以使用「支付宝当面付扫码支付」接口那?
答案是可以的,而且体验比「微信Native支付」好。
这是因为支付宝返回链接是一个标准 HTTP 连接,如下:
https://qr.alipay.com/xxxx
这个链接只要在支付宝内中打开,就可以唤起支付。
所以如果聚合收款码使用「支付宝当面付扫码支付」接口,收银台金额提交之后,当拿到支付宝返回的支付链接,应用程序内只要使用 HTTP 302 跳转到支付链接,就可以唤起支付宝支付。
❝画外音:之前我也一直以为支付宝跟微信一样,不能使用。
❞
那这样实际上聚合收款码底层使用支付方式就有了两种方案:
那如何选择那?个人建议使用第一种方案,微信、支付宝都采用 JSAPI 支付。
主要是因为只要 302 跳转唤起支付宝支付,就会关闭我们收银台页面,这样一来整个微信支付与支付宝支付流程就不太一样了
其次,当用户支付成功之后,JSAPI 支付还可以跳转到一个成功页面,这个页面我们可以支付结果展示,或者骚一点,还可以挂些广告,或者引流其他公号上。
但是如果使用付宝面付扫码支付,支付完成之后,页面就被关闭了,就没办法完成支付页面跳转。
介绍完原理,下面主要介绍一下市面上主流聚合收款码业务流程,其实聚合收款码可以分为三类:
静态聚合收款码就类似如下这种,需要用户主动输入金额,可以无限次使用。
静态收款码
而动态聚合收款码是只能使用一次,并且由商家指定金额,用户只要扫码就可以支付指定金额。
这种应用场景比如 B 站购买大会员:
银联静态二维码其实功能上与静态聚合收款码差不多,但是它多了支持银联支付的功能。
除了这个以外,最主要的区别是银联静态二维码是银联发码,背后对应的地址是银联的地址,类似如下:
https://qr.95516.com/00010000/xxx
静态聚合收款码主要支付流程主要可以分为二步,第一步为登录授权。
聚合收款码-登录授权
这里的登陆授权一般使用微信、支付宝匿名登录授权功能,这样这个过程普通用户其实是无感知的。
❝画外音:如果是程序员的话,可能会感受到这个过程经过了多次跳转。
❞
第二步,用户在收银台输入金额之后,应用内部将会创建相应的订单,然后再调用微信/支付宝的 JSAPI 支付。
聚合收款码-JSAPI支付
另外,如果支付宝采用面付扫码支付这种支付方式的话,那么其实不需要第一步登录授权了,可以直接跳到收银台发起支付。
聚合收款码-支付宝 native 支付
动态聚合收款码其实与静态收款码总体比较类似,只不过创建动态码内部已经创建了相应的订单,后续流程与静态聚合收款码差不多。
聚合收款码-动态码内部创单
如果你使用微信、支付宝扫码打开银联二维码,将会打开我们自己收银台页面,后续流程其实跟静态聚合收款码一模一样的。
但是如果你使用支付银联支付的 APP 扫码,比如说各大银行的手机 APP,美团,京东等,就会在这些 APP 内各自支付页面,然后完成支付。
我们银联二维码的功能,将会在银联后台报备一个跳转地址,比如说
https://www.heihei.com
当用户使用微信/支付宝访问银联二维码,银联后台自己识别访问请求 「User-Agent」 ,然后后台根据规则拼接重定向地址。
拼接规则如下:
https://www.heihei.com?qrCode=URLENCODE(https://qr.95516.com/00010000/xxx)
聚合收款码统一了用户支付流程,提高商家的收款效率。
另外聚合收款码其实还可以跟商家后台一些 ERP 等软件打通,这样还提高的商家生产效率。
不得不说,第一个设计出聚合收款码的的产品,真实个鬼才~
聚合收款码,背后原理一点也不难,根据用访问请求的 「User-Agent」 ,以此判断用户当前扫码使用的客户端类型。
然后调用微信/支付宝匿名登录获取用户 id,最后用户输入金额之后,调用微信/支付宝完成支付。
好了,今天文章介绍到这里,最后,点个赞再走吧~
嘻嘻吗,国庆就要到了,大家再熬几天!!!
本文由哈喽比特于4年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/tF_g5uFtdJ2bHYZn8Tinuw
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。