0

全部。我在 PayPal IPN 集成方面遇到问题,我似乎无法获得读取会话变量的解决方案。

基本上,在我的商店模块脚本中,我将 PayPal 提供的客户详细信息存储到订单表中。但是,我还希望将事务中订购的产品保存到由订单 ID 链接的单独表中。

但是,脚本的第二部分不起作用,我在会话中循环浏览产品,然后将它们保存到 orders_products 表。

会话数据未被读取是否有原因?

shop.php 中的代码如下:

if ($paypal->validate_ipn()) {
    $name = $paypal->ipn_data['address_name'];
    $street_1 = $paypal->ipn_data['address_street'];
    $street_2 = "";
    $city = $paypal->ipn_data['address_city'];
    $state = $paypal->ipn_data['address_state'];
    $zip = $paypal->ipn_data['address_zip'];
    $country = $paypal->ipn_data['address_country'];
    $txn_id = $paypal->ipn_data['txn_id'];
    $sql = "INSERT INTO orders (name, street_1, street_2, city, state, zip, country, txn_id)
            VALUES (:name, :street_1, :street_2, :city, :state, :zip, :country, :txn_id)";
    $smt = $this->pdo->prepare($sql);
    $smt->bindParam(':name', $name, PDO::PARAM_STR);
    $smt->bindParam(':street_1', $street_1, PDO::PARAM_STR);
    $smt->bindParam(':street_2', $street_2, PDO::PARAM_STR);
    $smt->bindParam(':city', $city, PDO::PARAM_STR);
    $smt->bindParam(':state', $state, PDO::PARAM_STR);
    $smt->bindParam(':zip', $zip, PDO::PARAM_STR);
    $smt->bindParam(':country', $country, PDO::PARAM_STR);
    $smt->bindParam(':txn_id', $txn_id, PDO::PARAM_INT);
    $smt->execute();
    // save products to orders relationship
    $order_id = $this->pdo->lastInsertId();
    // $cart = $this->session->get('cart');
    $cart = $this->session->get('cart');
    foreach ($cart as $product_id => $item) {
        $quantity = $item['quantity'];
        $sql = "INSERT INTO orders_products (order_id, product_id, quantity) VALUES ('$order_id', '$product_id', '$quantity')";
        $res = $this->pdo->query($sql);
    }
    $this->session->del('cart');
    mail('martin@mcbwebdesign.co.uk', 'IPN result', 'IPN was successful on wrestling-wear.com');
} else {
    mail('martin@mcbwebdesign.co.uk', 'IPN result', 'IPN failed on wrestling-wear.com');
}

我正在使用 PHP 的 PayPal IPN 类,如下所示:http: //www.micahcarrick.com/04-19-2005/php-paypal-ipn-integration-class.html,但该validate_ipn()方法的内容是如下:

public function validate_ipn()
{
    $url_parsed = parse_url($this->paypal_url);
    $post_string = '';
    foreach ($_POST as $field => $value) {
        $this->ipn_data[$field] = $value;
        $post_string.= $field.'='.urlencode(stripslashes($value)).'&';
    }
    $post_string.= "cmd=_notify-validate"; // append IPN command
    // open the connection to PayPal
    $fp = fsockopen($url_parsed[host], "80", $err_num, $err_str, 30);
    if (!$fp) {
        // could not open the connection. If logging is on, the error message will be in the log
        $this->last_error = "fsockopen error no. $errnum: $errstr";
        $this->log_ipn_results(false);
        return false;
    } else {
        // post the data back to PayPal
        fputs($fp, "POST $url_parsed[path] HTTP/1.1\r\n");
        fputs($fp, "Host: $url_parsed[host]\r\n");
        fputs($fp, "Content-type: application/x-www-form-urlencoded\r\n");
        fputs($fp, "Content-length: ".strlen($post_string)."\r\n");
        fputs($fp, "Connection: close\r\n\r\n");
        fputs($fp, $post_string . "\r\n\r\n");
        // loop through the response from the server and append to variable
        while (!feof($fp)) {
            $this->ipn_response.= fgets($fp, 1024);
        }
        fclose($fp); // close connection
    }
    if (eregi("VERIFIED", $this->ipn_response)) {
        // valid IPN transaction
        $this->log_ipn_results(true);
        return true;
    } else {
        // invalid IPN transaction; check the log for details
        $this->last_error = 'IPN Validation Failed.';
        $this->log_ipn_results(false);
        return false;
    }
}
4

2 回答 2

1

如果我没记错的话,PayPal IPN 会直接向您的脚本发送通知。由于通知来自 PayPal - 而不是下订单的客户 - 他们的会话在此上下文中不存在。因此,会话中不存在他们所有的购物车数据。

当我过去使用 IPN 时,我将有关他们订单的所有内容都存储在数据库中并生成了一个 TransactionID。这是我可以将其余订单发送到 PayPal 的传递变量之一,他们会将其传回。从 PayPal 收到 IPN 后,我根据 TransactionID 重新处理他们的订单,并继续执行我必须遵循的任何业务规则——发送电子邮件、创建密码等。

于 2010-05-02T22:48:18.583 回答
0

我目前正在处理这个问题——假设您正在尝试将会话 user_id 插入到您的事务表中,最好将 user_id 与订单一起发送到 Paypal。因为如果您在将它们重定向到 Paypal 后立即写入数据库,则无法保证他们确实完成了订单。此外,我认为 PayPal 以逗号分隔的字符串形式发回产品/订单信息,因此您需要查看所售出的独特商品的数量,并动态获取 item_id1、item_id2、item_id3 ...您的查询总是在变化。如果我错了,请纠正我,我即将开始实现它但不使用类。

于 2012-03-01T17:36:07.220 回答