php中的PayPal事务验证IPN返回INVALID

时间:2014-07-08 02:19:31

标签: php paypal-sandbox

我知道这个问题一直在这里被问到。但是没有一个解决方案适合我。

我正在尝试使用Sandbox验证PayPal交易。 我已经研究并发现了不同的代码,但没有一个代码响应我的代码,或者大多数PayPal返回INVALID


这是我的代码

header("HTTP/1.1 200 OK");
  // parse the paypal URL


$req = 'cmd=' . urlencode('_notify-validate');

foreach ($_GET as $key => $value) {
if (!is_array($value)) {
    $value = urlencode(stripslashes($value));
    $req .= "&$key=$value";
}else if (is_array($value)) {
    $paymentArray = explode(' ', $value[0]);
    $paymentCurrency = urlencode(stripslashes($paymentArray[0]));
    $paymentGross = urlencode(stripslashes($paymentArray[1]));
    $req .= '&mc_currency=' . $paymentCurrency . '&mc_gross=' . $paymentGross;
}
}

出于某种原因,我无法通过_POST获取任何信息,所以我尝试使用_GET。有什么想法吗?

echo $req;

$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, 'https://www.sandbox.paypal.com/cgi-bin/webscr');

curl_setopt($ch, CURLOPT_CAINFO, dirname(__FILE__)."/api_cert_chain.crt");

curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $req);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 1);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 2);
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Host: www.sandbox.paypal.com'));
$res = curl_exec($ch);
curl_close($ch);




if (strcmp ($res, "VERIFIED") == 0) {
echo "valid";
// check the payment_status is Completed
// check that txn_id has not been previously processed
// check that receiver_email is your Primary PayPal email
// check that payment_amount/payment_currency are correct
// process payment
}
else if (strcmp ($res, "INVALID") == 0) {
echo "invalid";
// log for manual investigation
}

毕竟,我得到的是INVALID,或者根本没有。
我还将证书放在我服务器的根目录中。

2 个答案:

答案 0 :(得分:1)

您是否尝试过使用此功能:

$data = file_get_contents('php://input');

答案 1 :(得分:0)

我的坏...转发PayPal确实在后台发送信号。我实际上是通过重定向尝试这个(在交易完成后PayPal收回原始来源)..这不会从PayPal获得太多信息。总的来说,如果有人想知道,代码工作正常。还需要删除沙盒'用于真实交易。