首先,感谢您的关注。来试探。
我正在使用这个 IPN 侦听器代码:
// IPN LISTENER
// intercetta le variabili IPN inviate da PayPal
$req = 'cmd=_notify-validate';
// legge l'intero contenuto dell'array POST
foreach ($_POST as $key => $value) {
$value = urlencode(stripslashes($value));
$req .= "&$key=$value";
}
// intestazione, prepara le variabili PayPal per la validazione
$header = "POST /cgi-bin/webscr HTTP/1.1\r\n";
$header .= "Content-Type: application/x-www-form-urlencoded\r\n";
$header .= "Host: www.sandbox.paypal.com\r\n"; // www.paypal.com for a live site
$header .= "Content-Length: " . strlen($req) . "\r\n";
$header .= "Connection: close\r\n\r\n";
// apre una connessione al socket PayPal
$fp = fsockopen ('ssl://www.sandbox.paypal.com', 443, $errno, $errstr, 30);
// converte le variabili inviate da IPN in variabili locali
$txn_id = filter_var($_POST['txn_id'], FILTER_SANITIZE_STRING);
$payment_status = filter_var($_POST['payment_status'], FILTER_SANITIZE_STRING);
$receiver_email = filter_var($_POST['receiver_email'], FILTER_SANITIZE_EMAIL);
$payer_email = filter_var($_POST['payer_email'], FILTER_SANITIZE_EMAIL);
$first_name = filter_var($_POST['first_name'], FILTER_SANITIZE_STRING);
$last_name = filter_var($_POST['last_name'], FILTER_SANITIZE_STRING);
$address_street = filter_var($_POST['address_street'], FILTER_SANITIZE_STRING);
$address_city = filter_var($_POST['address_city'], FILTER_SANITIZE_STRING);
$address_state = filter_var($_POST['address_state'], FILTER_SANITIZE_STRING);
$address_zip = filter_var($_POST['address_zip'], FILTER_SANITIZE_STRING);
// verifica l'apertura della connessione al socket
if (!$fp) {
// se la connessione non avviene l'esecuzione dello script viene bloccata
print("connessione PayPal non avvenuta, si prega di riprovare piu' tardi");
// in alternativa è per esempio possibile inviare un'email al venditore
} else {
// elaborazione delle informazioni
fputs ($fp, $header . $req);
while (!feof($fp)) {
$res = fgets ($fp, 1024);
// azioni in caso di risposta positiva da parte di PayPal
if (stripos($res, "VERIFIED") !== false) {
$myvariables = 1;
$anothermyvariables = "INSERT INTO MyDB ( paid, name, email, date)
VALUES ('". $txn_id ."','" . $first_name ." ". $last_name . "','" . $payer_email ."','". the_date('Y-m-d','','',FALSE) . "');";
$wpdb->query($anothermyvariables);
}
}
// azione in caso di risposta negativa da parte di PayPal else
if (stripos($res, "INVALID") !== false) {
$anothervariablesofmine = 2;
$paypalerr = "Pagamento non riuscito!"; // Payment not success!
}
}
// chiusura della sorgente di dati
fclose($fp);
var_dump
它以前确实有效,但现在不行……我已经测试了 PayPal 使用和返回我的网站的变量payment_status=Completed
。他们似乎没问题。
我已经测试了连接是否建立并且它也可以工作:
if (!$fp) {
ecc..
} else {
print("Connection Established");
etc....
问题来自变量stripos($res, "VERIFIED")
stripos($res, "INVALID")
。
var_dump
两者都返回为bool (false)
.
查看沙盒配置文件历史(买卖双方),所有交易结果均已完成。但让我抓狂的是,一周后完美运行……我已经搜索了 PayPal 的 IPN 侦听器端口、主机或变量的一些变化,但似乎没有任何变化。正确的?
我直接在购买表单的页面中写了IPN Listener,这意味着IPN Listener也被调用,没有$_POST
变量。对我来说,唯一可能的回复是来自 PayPal 端的 IPN 侦听器的垃圾邮件保护,它阻止了我,这可能吗?因为在没有 的情况下也调用了 Listener cmd=_notify-validate
,但它只是不起作用(但打了一个空白电话,PayPal 可能不太欣赏)。
编辑:
对不起,重新调试(上帝保佑var_dump
)。放入var_dump
while循环中:
....
while (!feof($fp)) {
$res = fgets ($fp, 1024);
var_dump(stripos($res, "VERIFIED"));
print("<br> VERIFIED". stripos($res, "VERIFIED") ."<br>");
var_dump(stripos($res, "INVALID"));
print("<br> INVALID". stripos($res, "INVALID") ."<br>");
...
并找到一个VERIFIED int(0)
而不是bool (false)
我刚刚改变
if (stripos($res, "VERIFIED") !== false) {
至
if (stripos($res, "VERIFIED") == 0) {
我认为INVALID
以防万一。
但我仍然不确定这是否正确。
那是问题吗?或者我可能需要更改其他内容?我可以同时使用两个if
条件(if == 0
和if !== false
)吗?PayPal 刚刚更改了VERIFIED
返回值?