我知道这个问题一直在这里被问到。但是没有一个解决方案适合我。
我正在尝试使用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,或者根本没有。
我还将证书放在我服务器的根目录中。
答案 0 :(得分:1)
您是否尝试过使用此功能:
$data = file_get_contents('php://input');
答案 1 :(得分:0)
我的坏...转发PayPal确实在后台发送信号。我实际上是通过重定向尝试这个(在交易完成后PayPal收回原始来源)..这不会从PayPal获得太多信息。总的来说,如果有人想知道,代码工作正常。还需要删除沙盒'用于真实交易。