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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DNA和纳米(Nano)Fusion技术的发展趋势

    DNA和纳米(Nano)Fusion技术的发展趋势

    2022年1月11日
    39
  • flume和kafka区别

    flume和kafka区别kafka和flume都是日志系统,kafka是分布式消息中间件,自带存储;flume每一部分都是可以定制。kafka更合适做日志缓存,flume数据采集部分做的很好,可以定制很多数据源,减少开发量。kafka和flume都是日志系统,kafka是分布式消息中间件,自带存储,提供push和pull存取数据功能。flume分为agent(数据采集器),collector(数据简单处理和写入),storage(存储器)三部分,每一部分都是可以定制的。比如agent采用RPC(Thri.

    2022年6月23日
    24
  • knox芯片_推广代理平台

    knox芯片_推广代理平台使用knox进行正向和反向代理,并且进行一些权限认证,使用起来很方便,特别是对于NiFi的相关权限认证(ldap),所以本章节讲下我使用knox代理的服务,以及相关的一些配置选项。/gateway/san在这里面的每个xml被视为一个集群,集群中可以有多个service。topologies目录下的xml文件才会被加载,如果下面有文件夹不会继续查找。默认已经帮我们把所有的配置好了,所以只需要更改下面service的ip就行。这里创建了一个master秘钥,是给knoxgateway的秘钥。

    2022年10月25日
    0
  • Spring Boot+Redis+拦截器+自定义Annotation实现接口自动幂等

    前言 在实际的开发项目中,一个对外暴露的接口往往会面临很多次请求,我们来解释一下幂等的概念:任意多次执行所产生的影响均与一次执行的影响相同。按照这个含义,最终的含义就是 对数据库的…

    2021年6月22日
    121
  • vue判断字符串是否含有另一个字符串_js中判断是否包含某个字符串

    vue判断字符串是否含有另一个字符串_js中判断是否包含某个字符串String对象的方法1.indexOf()indexOf()方法可返回某个指定的字符串值在字符串中首次出现的位置。如果要检索的字符串值没有出现,则该方法返回-1。varstr=’你好啊双11!’;console.log(str.indexOf(‘!’)!=-1)//true2.search()search()方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字…

    2022年9月28日
    0
  • BP神经网络原理推导

    BP神经网络原理推导本文会完成BP神经网络的推导过程,先介绍BP神经网络的历史,然后介绍BP神经网络的结构,然后再开始推导,最后介绍BP神经网络的优缺点以及几个优化的方法。

    2022年7月20日
    10

发表回复

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

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