Paypal实现循环扣款(订阅)功能

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了Paypal实现循环扣款(订阅)功能脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

起因

@H_404_3@

业务需求要集成Paypal,实现循环扣款功能,然而百度GOOGLE了一圈,除官网外,没找到相关开发教程,只好在Paypal上看,花了两天后集成成功,这里对如何使用Paypal的支付接口做下总结。@H_404_3@

Paypal现在有多套接口:

@H_404_3@
  • 通过braintree(后面会谈Braintree)实现Ex@R_512_1313@ Checkout;
  • 创建App,通过REST Api的接口方式(现在的主流接口方式);
  • NVP/SOAP API apps的接口(旧接口);

Braintree的接口

@H_404_3@

Braintree是Paypal收购的一家公司,它除了支持Paypal的支付外,还提供了升级计划,信用卡,客户信息等一系列全套的管理,使用上更方便;这些功能Paypal第二套REST接口其实也集成了大部分,但是Paypal的dashboard不能直接管理这些信息而Braintree可以,所以我其实我更愿意用Braintree。关键是我使用的后端框架是Laravel,它的cashier解决方认可以支持Braintee,所以这套接口是我的首选。但是当我把它的功能都实现后发现一个蛋疼的问题:Braintree在国内不支持。。。。。。卒。。。@H_404_3@

REST API

@H_404_3@

这是顺应时代发展的产物,如果你之前用过OAuth 2.0与REST API,那看这些接口应该不会有什么困惑。@H_404_3@

旧接口

@H_404_3@

除非REST API接口有不能满足的,比如政策限制,否则不推荐使用。全世界都在往OAuth 2.0的认证方式和REST API的API使用方式迁移,干嘛逆势而行呢。因此在REST API能解决问题情况下,我也没对这套接口做深入比较。@H_404_3@

REST API的介绍

@H_404_3@

官方的API参考文档对于其API和使用方式有较详细的介绍,但是如果自己直接调这些API还是很繁琐的,同时我们只想尽快完成业务要求而不是陷入对API的深入了解

那么如何开始呢,建议直接安装官方提供的,通过其Wiki作为起点。@H_404_3@

在完成首个例子之前,请确保你有SandBox帐号,并正确配置了:@H_404_3@

  • Client ID
  • Client Secret
  • Webhook API(必须是https开头且是443端口,本地调试建议结合ngrok反向代理生成地址)
  • Returnurl(注意项同上)

在完成Wiki的首个例子后,理解下接口的分类有助于完成你的业务需求,下面我对接口分类做个介绍,请结合例子理解

  • Payments

    一次性支付接口,不支持循环捐款。主要支付内容有支持Paypal支付,信用卡支付,通过已保存的信用卡支持(需要使用Vault接口,会有这样的接口主要是pci的要求,不允许一般的网站采集信用卡的敏感信息),支持付给第三方收款人。
  • Payouts

    没用到,忽略;
  • Authorization and Capture

    支持直接通过Paypal的帐号登陆你的网站,并获取相关信息;
  • Sale

    商城有关,没用到,忽略;
  • Order

    跟商城有关,没用到,忽略;
  • Billing Plan & Agreements

    升级计划和签约,也就是订阅功能,实现循环扣款必须使用这里的功能,这是本文的重点;
  • Vault

    存储信用卡信息
  • Payment Experience

    没用到,忽略;
  • Notifications

    处理

    Webhook

    的信息,重要,但不是本文关注内容;
  • Invoice

    票据处理;
  • IdentITy

    认证处理,实现OAuth 2.0的登陆,获取对应token以便请求其他API,这块Paypal-PHP-sDK已经做进去,本文也不谈。

如何实现循环扣款

分四个步骤:

  1. 创建升级计划,并激活;
  2. 创建订阅(创建Agreement),然后将跳转到Paypal的网站等待用户同意;
  3. 用户同意后,执行订阅
  4. 获取扣款帐单

1.创建升级计划

升级计划对应Plan这个类。这一步有几个注意点:

  • 升级计划创建后,处于CREATED状态,必须将状态修改为ACTIVE才能正常使用。
  • Plan有PaymentDefinition和MerchantPReferences两个对象,这两个对象都不能为空;
  • 如果想创建TRIAL类型的计划,该计划还必须有配套的REGULAR的支付定义,否则会报错;
  • 看代码有调用一个setSETUPFee(非常,非常,非常重要)方法,该方法设置了完成订阅后首次扣款的费用,而Agreement对象的循环扣款方法设置的是第2次开始时的费用。

以创建一个Standard的计划为例,其参数如下:

 "standard_monthly","display_name" => "Standard Plan","desc" => "standard Plan for one month","tyPE" => "REGULAR","frequency" => "MONTH","frequency_interval" => 1,"cycles" => 0,"amount" => 20,"currency" => "USD"
 ];

脚本宝典总结

以上是脚本宝典为你收集整理的Paypal实现循环扣款(订阅)功能全部内容,希望文章能够帮你解决Paypal实现循环扣款(订阅)功能所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:paypal订阅