草庐IT

php - PayPal REST API 订单工作流程 : Payment -> Sale -> Webhook?

coder 2024-01-04 原文

我正在尝试将 PayPal REST API 集成到我的 Symfony 2 网络应用程序中,但我发现很难理解完整的工作流程到底是什么样的:

PayPal docs描述以下接受付款的步骤。可以使用 PayPal Playground模拟这些步骤:

  1. 获取访问 token
  2. 通过查询 API 创建 Payment 对象
  3. 将用户重定向到 Payment 响应中收到的 approval url
  4. 用户在 PayPal 页面上批准付款后,他将使用 Payment 对象中定义的成功链接重定向回我的页面。使用收到的信息执行付款。
  5. 付款已完成,状态为approved

From the docs: Once a payment is complete, it is referred to as a sale. You can then look up the sale and refund it.

到目前为止一切顺利。但是: 在此工作流程中,Webhook 在哪里使用/触发?我在 PayPal Developer Dashboard 中定义了一个通配符 Webhook(接受所有可能的事件)。

我的观察是,我的系统在 1-2 分钟 (!) 用户被重定向回成功链接和 后收到 Webhook 事件付款执行后(第 4 步)

除了执行付款和接收 Webhook 之间的长时间延迟之外,此工作流意味着我只在处理成功链接后 AFTER 收到 Webhook。 这意味着,处理成功链接对于完成支付是绝对必要的。这是正确的吗?

我需要使用 Webhook 吗?

我已经问过了this question几天前,nifr 的回答非常合理:不能相信用户会遵循任何重定向 URL,而应该只依赖 Webhook 事件。

然而,这与我之前描述的观察结果相冲突,因为我永远不会在不处理重定向 URL 的情况下收到 Webhook...

因此,处理 PAYMENT.SALE.COMPLETED webhook 事件没有多大意义,因为这应该在处理重定向 URL 时已经完成。 正确吗?

但是,要处理待处理付款的更新、处理退款或撤消付款等,只能通过监听这些事件来实现。

所以答案是:仅使用 Webhooks 获取之前付款的更新。正确吗?

所以,主要问题是:

  1. 接受付款的 5 步流程并未提及使用 Webhooks。这似乎没有多大意义,因为如果没有 Webhooks,人们会错过更新事件等吗? 那么,真的可以不用Webhooks实现完整的支付流程吗?
  2. 如果是,在这种情况下如何处理更新(退款、待定等)?
  3. 如果不是,完成订单的正确策略/时间是什么,因为完全接收和处理 webhook 需要相当长的时间?

最佳答案

我仍然是 PayPal 世界的新手,但几天前我在一家在线商店中集成了 PayPal Plus REST API,根据我的理解,我可以看出工作流程如下:

  1. 创建付款
  2. 重定向到 Paypal
  3. 付款人可以使用 PayPal 账户支付(使用银行直接借记或没有 PayPal 账户的信用卡支付)
  4. 在 PayPal 端完成流程后,PayPal 会将用户重定向回您的成功 URL。
  5. 直到现在用户仍未被收费(你没有钱)。在您(在您的成功 URL 中)执行 $payment->execute($paymentExecution,$api); 的那一刻,您要求 Paypal 向用户收取金额。但是在此之后,您也没有钱。 Paypal 必须先处理收费,然后通过 WebhookEvents 通知您。

当用户通过直接借记卡或信用卡等方式付款时,Webhook 通知(具有令人讨厌的延迟)尤为重要。处理此类付款需要几秒钟/几分钟。

redirectUrl 对于收取/执行付款是绝对必要的。 这里执行成功,只是为了告诉用户,他完成了他的工作,你可以在这里保存/捕获 PaymentID/Transaction id 以供以后使用/通过 WebhookEvent Listener 更新。

所以我建议您仅在通过 WebhookEvent Listener 收到通知后更新您的数据库(付款已完成),而不是在成功的 RedirectUrl 中。

关于php - PayPal REST API 订单工作流程 : Payment -> Sale -> Webhook?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36278462/

有关php - PayPal REST API 订单工作流程 : Payment -> Sale -> Webhook?的更多相关文章

  1. ruby-on-rails - 由于 "wkhtmltopdf",PDFKIT 显然无法正常工作 - 2

    我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-

  2. ruby-on-rails - 'compass watch' 是如何工作的/它是如何与 rails 一起使用的 - 2

    我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t

  3. ruby-on-rails - 如何从 format.xml 中删除 <hash></hash> - 2

    我有一个对象has_many应呈现为xml的子对象。这不是问题。我的问题是我创建了一个Hash包含此数据,就像解析器需要它一样。但是rails自动将整个文件包含在.........我需要摆脱type="array"和我该如何处理?我没有在文档中找到任何内容。 最佳答案 我遇到了同样的问题;这是我的XML:我在用这个:entries.to_xml将散列数据转换为XML,但这会将条目的数据包装到中所以我修改了:entries.to_xml(root:"Contacts")但这仍然将转换后的XML包装在“联系人”中,将我的XML代码修改为

  4. ruby - 无法让 RSpec 工作—— 'require' : cannot load such file - 2

    我花了三天的时间用头撞墙,试图弄清楚为什么简单的“rake”不能通过我的规范文件。如果您遇到这种情况:任何文件夹路径中都不要有空格!。严重地。事实上,从现在开始,您命名的任何内容都没有空格。这是我的控制台输出:(在/Users/*****/Desktop/LearningRuby/learn_ruby)$rake/Users/*******/Desktop/LearningRuby/learn_ruby/00_hello/hello_spec.rb:116:in`require':cannotloadsuchfile--hello(LoadError) 最佳

  5. ruby-on-rails - rspec should have_select ('cars' , :options => ['volvo' , 'saab' ] 不工作 - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion在首页我有:汽车:VolvoSaabMercedesAudistatic_pages_spec.rb中的测试代码:it"shouldhavetherightselect"dovisithome_pathit{shouldhave_select('cars',:options=>['volvo','saab','mercedes','audi'])}end响应是rspec./spec/request

  6. ruby-on-rails - s3_direct_upload 在生产服务器中不工作 - 2

    在Rails4.0.2中,我使用s3_direct_upload和aws-sdkgems直接为s3存储桶上传文件。在开发环境中它工作正常,但在生产环境中它会抛出如下错误,ActionView::Template::Error(noimplicitconversionofnilintoString)在View中,create_cv_url,:id=>"s3_uploader",:key=>"cv_uploads/{unique_id}/${filename}",:key_starts_with=>"cv_uploads/",:callback_param=>"cv[direct_uplo

  7. ruby-on-rails - Nokogiri:使用 XPath 搜索 <div> - 2

    我使用Nokogiri(Rubygem)css搜索寻找某些在我的html里面。看起来Nokogiri的css搜索不喜欢正则表达式。我想切换到Nokogiri的xpath搜索,因为这似乎支持搜索字符串中的正则表达式。如何在xpath搜索中实现下面提到的(伪)css搜索?require'rubygems'require'nokogiri'value=Nokogiri::HTML.parse(ABBlaCD3"HTML_END#my_blockisgivenmy_bl="1"#my_eqcorrespondstothisregexmy_eq="\/[0-9]+\/"#FIXMEThefoll

  8. ruby - JetBrains RubyMine 3.2.4 调试器不工作 - 2

    使用Ruby1.9.2运行IDE提示说需要gemruby​​-debug-base19x并提供安装它。但是,在尝试安装它时会显示消息Failedtoinstallgems.Followinggemswerenotinstalled:C:/ProgramFiles(x86)/JetBrains/RubyMine3.2.4/rb/gems/ruby-debug-base19x-0.11.30.pre2.gem:Errorinstallingruby-debug-base19x-0.11.30.pre2.gem:The'linecache19'nativegemrequiresinstall

  9. ruby - `rescue $!` 是如何工作的? - 2

    我知道全局变量$!包含最新的异常对象,但我对下面的语法感到困惑。谁能帮助我理解以下语法?rescue$! 最佳答案 此构造可防止异常停止您的程序并使堆栈跟踪冒泡。它还会将该异常作为值返回,这很有用。a=get_me_datarescue$!在此行之后,a将保存请求的数据或异常。然后您可以分析该异常并采取相应措施。defget_me_dataraise'Nodataforyou'enda=get_me_datarescue$!puts"Executioncarrieson"pa#>>Executioncarrieson#>>#更现实的

  10. ruby - File.read ("| echo mystring") 是如何工作的? - 2

    我在我正在处理的一些代码中发现了这一点。它旨在解决从磁盘读取key文件的要求。在生产环境中,key文件的内容位于环境变量中。旧代码:key=File.read('path/to/key.pem')新代码:key=File.read('|echo$KEY_VARIABLE')这是如何工作的? 最佳答案 来自IOdocs:Astringstartingwith“|”indicatesasubprocess.Theremainderofthestringfollowingthe“|”isinvokedasaprocesswithappro

随机推荐