如何确保网站的paypal集成

时间:2011-09-21 11:33:08

标签: php paypal integration payment-gateway

我过去一直使用paypal通过我的网站销售东西(例如会员资格)但我总是必须通过paypal验证用户是否真的购买了会员资格(例如)才能将其分配给他/她的帐户。现在我想知道是否有一种方法可以将paypal购买按钮放到我的网页上(例如)购买会员资格,然后一旦用户付款,他将自动被分配到我的网站上的会员资格(例如,有一个页面purchase_result.php指定会员资格,但仅在用户真正通过paypal购买时才会这样做。如何确保用户在我网站的返回页面上通过paypal实际购买了该商品?

提前致谢, Skyfe。

顺便说一下,我希望我的问题可以理解

1 个答案:

答案 0 :(得分:8)

您可以通过PayPal即时付款通知接收来自PayPal的服务器到服务器通知,您可以随后验证并使用它来更新您的数据库。

IPN的工作原理如下:

  1. 您创建PayPal并包含“notify_url”。此参数的值将是服务器上脚本的完整URL,称为“IPN脚本”或“IPN处理程序”。
  2. 您可以为网站付款标准指定IPN处理程序,如下所示 <input type="hidden" name="notify_url" value="http://blah.com/ipn.php

    对于Express Checkout或Website Payments Pro,只需在SetExpressCheckout / DoExpressCheckoutPayment或DoDirectPayment API调用中分别包含以下内容即可。     NOTIFYURL=http://blah.com/ipn.php

    1. 买方通过PayPal完成交易
    2. 买家完成交易后,他/她可以关闭浏览器或返回您的网站
    3. PayPal接受并处理交易后,PayPal会向http://blah.com/ipn.php发送通知
    4. 您需要获取发送到此脚本的所有POST数据,并将其重新发送回https://www.paypal.com/cgi-bin/webscr?cmd=_notify-validate
    5. 如果您发回的数据与PayPal发送给您的数据一致,则会返回“已验证”的回复。
    6. 如果回复是经过验证的,那么您可以在此时查找匹配的交易/买方,并适当更新您的数据库。
    7. PayPal IPN的一些示例代码和文档可在https://www.paypal.com/ipn/发送 此外,https://www.x.com/developers/community/blogs/ppmtsrobertg/securing-your-instant-payment-notification-ipn-script

      提供了有关制作安全IPN脚本的一些提示

      注意:如果您想要包含任何自定义数据以及稍后可以阅读的交易,请使用“自定义”。
          <input type="hidden" name="custom" value="xxxxx">
      这也将在PayPal发送的IPN POST数据中返回。