2

我正在使用贝宝订阅和即时支付通知 (IPN) 来处理我网站上的订阅者。

在大多数情况下,它运行良好,但我偶尔会遇到一个问题。

通常,如果用户取消订阅,我会等待“期限结束”(subscr_eot)通知,然后再禁用对我网站的访问。

因此,如果他们预付了整个月的费用,然后立即取消,他们仍然可以在本月的剩余时间内访问(应该如此)。

但是一些用户遇到了这个问题,他们:

  1. 取消他们的订阅
  2. 在达到“期限结束”之前,他们决定重新订阅
  3. 当他们的第一次订阅达到“期限结束”时,我的应用程序会收到通知并向用户发送一封电子邮件,其中包含“您的帐户已被禁用,如果您想再次注册,您可以重新-点击这里订阅”。
  4. 这让他们感到困惑,因为他们在想……这很奇怪,我以为我像一周前一样订阅了(他们确实做到了)。所以他们再次订阅。现在他们有两个同时运行的订阅我的网站,我在一两个月内收到一封支持电子邮件(“你这个月向我收费两次,混蛋!!”)

所以我还没有找到解决这个问题的好方法。我想最好的解决方案是在收到“期限结束”通知时进行额外的 API 调用,该通知询问贝宝“嘿,这个人已经重新订阅了吗?”。如果是这样,则无需关闭该电子邮件。但是我还没有看到任何方法来做这个 API 调用。

另一种解决方案是在他们取消时立即禁用他们的帐户(“subscr_cancel”通知),但随后我收到不同的愤怒支持电子邮件“嘿,我预付了整个月的费用,为什么我的帐户已经被禁用了!!”。

其他人解决了这个问题吗?

4

4 回答 4

1

我知道这是一个旧线程,但我还没有看到这个问题的实际答案,所以如果有人碰巧像我一样想知道这个问题,这里有一个解决方案。

如果有人在他们的任期结束(subscr_eot)之前取消他们的帐户(subscr_cancel),我会在我的数据库中设置它来处理它。例如,如果您的数据库中有一个“Users”表,只需添加一个新的“int”字段并将其命名为“Term”。默认情况下,该字段应设置为“0”。然后,在您的 IPN 中进行设置,以便如果用户在期限结束前取消订阅,它将将该用户的“期限”字段设置为“1”。如果该用户返回并重新订阅您的服务,则让 IPN 将该用户的“期限”字段更新回“0”。

然后,在您的邮件脚本中,当它运行到任期结束时,让它检查该用户的“任期”字段。如果它设置为“0”,则不要发送电子邮件。如果设置为“1”,则发送电子邮件说“再见!”

于 2011-04-11T13:28:08.390 回答
0

如何防止重复 PayPal 付款?

您可能希望为“invoice”参数添加一个唯一标识符;并在您的帐户 www.paypal.com 的“个人资料”>“我的销售工具”部分启用“阻止重复付款”

于 2013-08-02T08:57:19.913 回答
0

据我所知,如果您使用的是网站支付标准/专业按钮,则没有 paypal api 来检查订阅,我假设您是。

我通过在我的数据库中保持活动/取消/重新订阅状态并根据我从贝宝获得的 IPN 消息更新状态来处理这个问题。我使用按钮中的字段将 IPN 消息映射到我的用途,该custom字段会在每条 IPN 消息上发送回来。

还有很多第三方可以帮助您管理这个过程,因为 paypal 的 api 在这方面有点薄弱。Recurly 是我研究过并计划实施的一个,还有其他的。

于 2010-03-30T10:56:31.547 回答
0

引用: Re: subscr_eot 什么时候发布?

如果您在 2009 年 11 月之后开始接受订阅,则订阅者 ID 将以 ' I-' 开头 - 并且在其时间结束时不会返回 'subscr_eot'。贝宝希望您记下他们订阅了多长时间,并在该期限到期时更新帐户以降级(或其他),除非客户在此期间再次付款。

于 2010-06-29T17:06:36.680 回答