Paypal 实现自动订阅「建议收藏」

Paypal 实现自动订阅

大家好,又见面了,我是全栈君。

官方给出的自动续费分五步 Intergrate Subscriptions。实际开发中,还需要实现支付结果处理和订阅管理等:

  1. 事先创建计划,并激活;
  2. 用户创建订阅,跳转到paypal网站等待用户同意;
  3. 用户同意后,跳转回网站,执行订阅;
  4. 获取用户账单,包括每次扣款结果通知的接收或支付结果的主动查询;
  5. 处理用户取消订阅等通知。

使用 Palpal SDK

composer require paypal/rest-api-sdk-php

 

官方有完整的 Samples

可以通过 Paypal Sandbox 方便的进行调试。

创建订阅计划并激活

  • 订阅计划(Billing Plan)等同于的产品,需要为每个商品不同价格创建不同的计划。不过可以针对不同用户在创建协议时更改;
  • Payment 中创建 TRIAL 类型支付时,也必须存在 REGULAR 的支付。TRAIL 并不能自动判断是否为新用户等条件,所以新用户首次的优惠需要业务代码自己实现。
  • 由于创建用户订阅协议时,协议生效时间必须在当前时间24小时以后,所以循环扣款的设置无法立刻扣款,最早也需要24小时。一般业务需要立刻进行首次扣款,可以用 MerchantPreferences 的 setSetupFee 来设置首次扣款的费用;
  • Paypal SDK 会报错 "NotifyUrl" value is NULL,该错误为 Paypal 服务端错误,但官方未修复,解决办法见 issue

创建订阅

  • 用户可以创建针对同一订阅计划的多个订阅协议(Billing Agreement),创建后跳转至 Paypal 网站等待用户同意协议;

  • 因协议开始时间 start_date 最早为当前时间24小时之后,所以该值实际上设置的是第二次扣款时间。所以,若设置按月付款,start_date 需要设置成一个月以后,然后通过设置 setSetupFee 价格来设置首次扣款费用;

  • 创建订阅后,还没有生成 Agreement.id,这时候需要从跳转链接中提取出 token 来使创建的订阅与用户同意后跳转的回来的协议信息相对应。

$link = $agreement->getApprovalLink();
parse_str(parse_url($link, PHP_URL_QUERY), $params);
$token = $params['token'];
  •  

执行订阅

  • 同一个订阅计划可以被同一个用户多次订阅。所以根据需要,需要在执行新协议时,手动取消该用户之前的协议;
  • 实际扣款时间有延迟,每次循环扣款执行的时间,都会比AgreementDetail.next显示的时间晚几个小时。所以为保证连续性,可以设置提前一天扣款。

支付结果接收与查询

  • 可以在 My Apps -> REST API apps -> WEBHOOKS 设置 webhook 通知。当每次循环扣款成功时,Paypal 都会发送 PAYMENT.SALE.COMPLETED 的事件通知,可以通过其中的 billing_agreement_id 字段与已创建的订阅相匹配,找出对应付款的协议。
  • 每次 AgreementDetail 都会返回下次收款时间 next 参数。可以在超过这个时间后,通过 Agreement::searchTransactions 方法查询该协议的所有交易。需要注意的是,Paypal 实际的扣款时间一般都会延迟,所以需要多次重试。

用户订阅取消与删除等

  • 取消订阅会通过 webhook 发送 BILLING.SUBSCRIPTION.CANCELLED 通知,订阅暂停会发送 BILLING.SUBSCRIPTION.SUSPENDED 通知
  • 直接删除计划并不会自动删除基于该计划的协议,所以再删除计划前,需要手动取消所有订阅该计划的协议。

参考资料

https://developer.paypal.com/docs/subscriptions/

https://paypal.github.io/PayPal-PHP-SDK/sample/

https://www.cnblogs.com/pheye/p/6603126.html

https://bootell.net/2018/08/30/Paypay-Subscriptions-Integrate/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111576.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • LINUX上NIS服务配置

    LINUX上NIS服务配置

    2021年8月27日
    57
  • 网站访问不了

    网站访问不了

    2021年11月3日
    52
  • Scapy的介绍(一)「建议收藏」

    Scapy的介绍(一)「建议收藏」介绍关于Scapy的Scapy是一个Python程序,使用户能够发送,嗅探和剖析并伪造网络数据包。此功能允许构建可以探测,扫描或攻击网络的工具。换句话说,Scapy是一个功能强大的交互式数据包操作程序。它能够伪造或解码大量协议的数据包,通过线路发送,捕获它们,匹配请求和回复等等。Scapy可以轻松处理大多数经典任务,如扫描,跟踪路由,探测,单元测试,攻击或网络发现。它可以取代hping…

    2022年4月19日
    33
  • 从零开始学习EasyDarwin(概述篇)

    EasyDarin是什么  EasyDarwin是由国内开源流媒体团队维护的一款开源流媒体平台框架,从2012年12月创建并发展至今,从原有的单服务的流媒体服务器形式,扩展成现在的云平台架构的开源项目,更好地帮助广大流媒体开发者和创业型企业快速构建流媒体服务平台。EasyDarwin适合做什么  安防视频监控,移动互联网(安卓、IOS、微信)流媒体直播与点播,流媒体视

    2022年4月5日
    45
  • 无锁编程CAS[通俗易懂]

    无锁编程CAS[通俗易懂]前言CAS(CompareAndSwap,比较并交换),要说CAS是无锁编程,多多少少有些“标题党”的感觉。因为CAS根据其设计思想,可以划分为乐观锁。不同于synchronized关键字,synchronized实现的是悲观锁。我第一次听说乐观锁和悲观锁的时候有点震惊:一把锁我还得知道它乐不乐观?乐不乐观?一把锁难道还有情绪?实际上乐观锁和悲观锁是基于线程并发竞争的角度来说的,悲观锁就是…

    2022年6月10日
    42
  • kettle工具使用简明手册[通俗易懂]

    kettle工具使用简明手册[通俗易懂]kettle工具使用简明手册运行启动脚本spoon.bat快捷方式如果正确启动,则出现的主界面应该是下面这样的。初次进入需右键新建作业新建数据库连接也可以想下面一样,新建数据库连接向导填完参数测试一下连接通过向导分步来我已经建立了转换任务和数据库连接,可以直接应用。 建立多表复制点击开始即可,多表的…

    2022年10月9日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号