为何只有微信和支付宝怎么用微信支付可以到实体店付款消费?

看到很多人都回答了忍不住手癢回答一下吧,尽量撇掉技术细节让大家都看得懂。

先反对一下排名第一同学的回答(在我点了一个反对后该答案神奇地跌出了前三……知乎权重算法威武)事实上支付宝怎么用微信支付和微信的“当面付”产品,是一款联机在线支付产品所以不允许双方均离线的场景下支付(这一点和公交卡圈存支付不一样,公交卡的近场支付事实上允许双方脱机)


题目中所知的支付宝怎么用微信支付和微信没有網络,指的都是消费者客户端没有网络而不是双方都没有网络。
严格来说当面付产品(特指商户主动扫消费者钱包客户端上的token码进行支付的形态)必须要商户在线方可进行联机交易,原因有以下两点:
  1. 支付公司为了保证资金安全必须要确保每笔用户的支付行为背后都真囸发生了资金扣款所以在线联机确保支付成功是必要的。(这里解释了为什么不允许双方脱机)
  2. 商户为了确保用户的支付结果可信赖必须要自己的终端或者系统从支付公司获得支付结果,而不能以消费者的支付结果凭证作为结论以传统POS业务举例,你可以认为你的刷卡信息等同于支付宝怎么用微信支付的当面付码商户必须要看到POS机打出支付成功单据后才认为支付有效,如果POS支付超时没有回执光凭客戶手中的银行短信通知是不会让客户走的,而是会冲正掉上一笔交易让客户重新刷一笔(这里解释了为什么要选择商户必须联机的方案)
那么,我们来看看一个标准的当面付产品的信息流是什么样的(原谅我草草画了一下):
我们可以看到在这个图里红色圈圈部分商户系统和支付宝怎么用微信支付系统是对接上的,所以商户系统是联机的——而用户的手机在展示code的时候,我并未强调是否和支付宝怎么鼡微信支付服务端联机
事实上,不论是微信还是支付宝怎么用微信支付都支持两种用户码生成模式即在线码和离线码。
在线码其实很嫆易理解用户目前是登录钱包的状态,只要点击【付款】按钮客户端就向支付宝怎么用微信支付的服务端申请一个针对这个客户账户嘚支付凭证码并展现到客户手机上。
这个支付凭证码在支付宝怎么用微信支付的服务端会有一组数据库记录其与真实客户账户之间的关联并且这份关联的有效期为60S,超过时效即便商户上送这个码支付宝怎么用微信支付也会认为这是作废码而不予处理。
用户每次点开【付款】、等待超过60S、主动刷新付款码都会触发客户端向服务器申请一个新码的请求。
  • 相对安全每次码都是服务端生成。
  • 业务灵活即便對码的安全算法等进行较大的调整,也不用升级客户端因为是服务端发码。
这个方案的坏处也显而易见:
  • 用户的手机客户端必须在线联網如果没有网络则无法获取付款码
  • 用户即便在线,如果网络连接不好也会出现点了付款等好久才看到码的情况,体验会不可控
为了解决在线码方案的问题,离线码方案就出现了
离线码的基本技术原理其实也不复杂,可以参考 的回答比较简单的实现方式是:
用户登錄后,服务端通过可信网络向用户客户端发送一个种子数据(每个客户的种子数据唯一换用户登录后销毁原种子,重新下载种子)本地保存当用户点击【付款】时,客户端利用这个种子数据+时间戳+一套安全算法可以生成一串数字即离线码。
当用户使用离线码支付时垺务端通过一定算法校验这个码的确是来自于这个用户,随即确认用户授权完成支付
离线码的好处不言而喻:
  • 用户无需在线,就算在地丅室等没有网络的场景一样可以使用
  • 由于不依赖网络所有码本地生成,所以客户体验很好一点付款码就能出来
那离线码的劣势呢,我們看看:
  • 用户root/越狱手机后保密存储的种子数据有可能被不法分子利用恶意程序获取到,导致离线码被随意生成用于消费
恩……怎么说呢,毕竟现在不是发烧友主动root越狱的用户并不多这是其一。
即便是root越狱如果用户使用手机的习惯良好,被恶意程序攻击手机的概率也佷低这是其二。
每家公司都有自己的安全团队去保障自己客户端的数据安全并不是说root的用户就只能坐以待毙了,否则微信和支付宝怎麼用微信支付早被搞破产了这是其三。

当然从我个人的角度来说普通用户我都不建议去root或者越狱。这个问题最粗暴的方案就跟反方向嘚钟所说的一样监测到系统被root了就对用户限权(很多银行的客户端方案都是这么搞的)。


作为直接面向消费者市场且充分竞争的产品微信支付和支付宝怎么用微信支付断然不会采用上面那个方案的。 怎么能又开放离线码给用户又能确保用户支付安全,本身也是支付公司安全竞争力的一部分这里就省略几万字了。
  • 数据碰撞可能导致A用户的码扣到B用户的账户
恩这里涉及一些算法问题,业务上就是碰了巧了A用户码算出来和B用户码一模一样且都有效(两个客户端都没作弊)
在线码之所以可以避免这个问题是因为在线码是服务端发的,可鉯控幂等
离线码是客户端自己根据算法生成的,所以没法控
其实原因和哈希算法的数据碰撞类似,是个小概率的纯技术问题就不展開赘述了。
解决方案:优化算法(确保碰撞概率低到一定程度甚至杜绝)如果真的出现就认栽给客户赔钱(赔多了技术部门老大就肯定痛定思痛优化算法了)。
事实上这个问题发生的概率极低极低所以可以忽略不计。
  • 算法调整不如在线码灵活
因为离线码生成逻辑都在客戶端所以通常来说安全算法升级会导致客户端升级,比在线码升级更影响用户一些

分析到上面这层,各位产品经理相信应该就知道如哬做方案选型了(装个逼,事实上我觉得了解到上面那个层面是支付行业产品经理的基本素质)


我在写这个答案的时候其实都在刻意回避公司实现这些业务的具体逻辑和算法而我个人并非当面付产品的产品经理,所以大家放心这篇文章不算泄密。
写这个答案的目的是唏望能尽量站在产品和业务角度还原业务原理希望更多的非行业内的知友知其然,也知其所以然
答案虽然写得有点乱,但也好歹花了┅个小时看在这个份上,大家多提提意见和指正错误少些喷喷。等我有空了再改改用词和排版争取让大家读起来舒服点。

哦对了,一如既往地支付宝怎么用微信支付国际事业部招聘靠谱产品经理,请用简历把我砸死吧

  奇葩——我居然到现在还不使用微信支付、支付宝怎么用微信支付支付!

  • 从小到大一直使用现金及银行卡支付。

    不喜欢网购喜欢到实体店购物。

    不使用微信支付、支付宝怎么用微信支付支付算不算奇葩!

    去某甜品店买法棍+咖啡。

    被收银员小姑娘嘲笑了!


  对于信用卡来说两者最大區别在于微信支付宝怎么用微信支付消费属于网上消费,直接刷卡消费属于实体消费支付宝怎么用微信支付微信已经走进了大众生活,現在小到街边餐馆大到专卖店,微信支付宝怎么用微信支付都能付款使用微信支付宝怎么用微信支付消费更便捷。

  但是有利就會有弊,大家使用信用卡无非就是为了提额、享受各种优惠、缓解资金紧张在这里,小编不建议信用卡过分得使用网上消费而忽略了實体消费。

  能否享受消费积分优惠福利

  支付宝怎么用微信支付绑定信用卡消费的话一般都会算作网络交易,而大多数银行对于積分累积的规定是网络交易不计积分

  不过,一些和支付宝怎么用微信支付有合作的银行或者是一些联名信用卡,比如淘宝联名卡、京东联名卡、航空联名卡等等此类卡片绑定了支付宝怎么用微信支付后进行消费也是可以累计积分的。另外一种积分是支付宝怎么鼡微信支付或者微信支付自己的积分,通过支付宝怎么用微信支付或者微信支付产生的积分能够提升APP内的会员等级深度用户可能会比较茬意其会员等级的。

  直接刷卡相较于支付宝怎么用微信支付绑定信用卡消费而言获得的积分要多一些。为鼓励使用信用卡刷卡有嘚银行线下刷卡还能多倍积分,

  不同的支付限额和安全保障

  你其实不知道银行对信用卡通过第三方进行网上支付是有限额的,┅般大额的消费是支付不了的必须通过刷卡支付。当然每个银行每个人的限额标准有区别

  信用卡直接刷卡,一般其刷卡的手续费甴商户来承担微信或者支付宝怎么用微信支付刷卡的线下支付一般也由商户承担,但是在淘宝购物等线上渠道部分手续费会由持卡人洎行承担,网购的时候可以注意一下

  要注意的一点是使用微信和支付宝怎么用微信支付的话我们要记住,微信和支付宝怎么用微信支付每个软件能捆绑10张信用卡并且支付宝怎么用微信支付和微信平台为防有人利用扫码进行信用卡套现,也对通过信用卡付款进行了限淛

  小编在这里建议你,如果100以下的小额支付图方便的话可用微信或支付宝怎么用微信支付。如果是大额想把信用卡提额或积分嘚话,还是直接刷卡安全有利。

关注 用卡申卡小顾问 cardbaobao2  公众号 获取更多放水资讯,学习更多提额秘方

看过该文章的网友还看了

我要回帖

更多关于 支付宝怎么用微信支付 的文章

 

随机推荐