首页 > 解决方案 > 贝宝按钮订阅和添加到数据库

问题描述

我在我的网站上设置了一个 PayPal 订阅按钮。我想成功订阅,我将买家添加subscriptionID到我的数据库中。

  paypal.Buttons({
      createSubscription: function(data, actions) {
        return actions.subscription.create({
          'plan_id': 'P-PLANID'
        });
      },
      onApprove: function(data, actions) {
        $.ajax({
            url: 'subscription_capture.php',
            type: 'post',
            data: { subid: data.subscriptionID},
            async: false,
            success: function(d) {
                location.reload();
            },
        });
      }
  }).render('#paypal-button-container');

订阅捕获.php

if(isset($_POST) and isset($_POST['subid'])){
    include 'db.php';;
    $query = $db->prepare("INSERT INTO `subscription` (`user_id`,`subscriptionID`) VALUES(?,?)");
    $query->bind_param('ss', $user_id, $_POST['subid']);
    $query->execute();
}

然而,这并不安全,因为任何查看代码的人都可以手动发送POST请求subscription_capture.php以可能绕过订阅。有没有更好的方法来处理成功的订阅并将订阅 ID 添加到我的数据库中?

我读到 Paypal 的 Button 是一种比设置 PayPalIPN 更简单的方式来处理付款。

标签: phpmysqlpaypalpaypal-ipn

解决方案


要接收订阅被激活的安全通知,请注册webhook 事件,例如BILLING.SUBSCRIPTION.ACTIVATED(已激活配置文件)或PAYMENT.SALE.COMPLETED(已付款)

Webhook 是非常古老的 IPN 服务的继承者。


推荐阅读