2013-04-29 1 views
0

Я проверил все в песочнице, слушатель IPN работал бы так, как ожидалось, и я ожидал ответы в своей почте.Страница PayPal IPN не попадает, хотя покупка проходит через

Я уже сейчас живу, но покупатель может разместить штраф за покупку, а PayPal даже дает идентификатор транзакции покупки, кажется, что слушатель IPN перестает работать, он никогда не слышит IPN из PayPal, и поэтому никто обработки бизнес-логики, которая должна произойти, срабатывает всякий раз, когда совершается покупка. Что не так?

Нет ничего плохого в моем коде прослушивателя IPN, потому что он отлично работал в среде песочницы. Я использовал этот код IPN: https://github.com/Quixotix/PHP-PayPal-IPN

Это совсем не попадает. Это, как я использую запрос NVP:

$return_url = urlencode("http://www.zeej.com.sa/printshop/checkout4_confirm.php"); 
$cancel_url = urlencode("http://www.zeej.com.sa/printshop/cancel.php"); 
$notify_url = urlencode("http://www.zeej.com.sa/printshop/ipn.php"); 
$nvpStr ="&BUTTONCODE=HOSTED&BUTTONTYPE=BUYNOW&L_BUTTONVAR1=amount=".$usd_total."&L_BUTTONVAR2=return=".$return_url."&L_BUTTONVAR3=cancel_return=".$cancel_url."&L_BUTTONVAR4=no_shipping=1&L_BUTTONVAR5=notify_url=".$notify_url."&L_BUTTONVAR6=custom=".$custom_qs; 

$httpParsedResponseAr = PPHttpPost('BMCreateButton', $nvpStr); 

if("SUCCESS" == strtoupper($httpParsedResponseAr["ACK"]) || "SUCCESSWITHWARNING" == strtoupper($httpParsedResponseAr["ACK"])) { 
    $hostedbuttonid = $httpParsedResponseAr["HOSTEDBUTTONID"]; 
} else { 
    die('Please refresh the page and try again. <br />Error: Create Payment Button Failed: ' . print_r($httpParsedResponseAr, true)); 
} 

И это мой PPHttpPost код, который я получил где-то в Интернете, и отлично работает хорошо во время песочнице тестирования:

function PPHttpPost($methodName_, $nvpStr_) { 
    global $environment; 
    $environment = ""; 

    // Set up your API credentials, PayPal end point, and API version. 


    $API_UserName = urlencode('xxxxxxxxxxxxxxxxxxxxxxxxxxx'); 
    $API_Password = urlencode('xxxxxxxxxxxxxxxxxxxxxxxxxxx'); 
    $API_Signature = urlencode('xxxxxxxxxxxxxxxxxxxxxxxxxx'); 

    $API_Endpoint = "https://api-3t.paypal.com/nvp"; // 
    if("sandbox" === $environment || "beta-sandbox" === $environment) { 
     $API_Endpoint = "https://api-3t.$environment.paypal.com/nvp"; 
    } 
    $version = urlencode('98.0'); 

    // Set the curl parameters. 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, $API_Endpoint); 
    curl_setopt($ch, CURLOPT_VERBOSE, 1); 

    // Turn off the server and peer verification (TrustManager Concept). 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE); 

    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_POST, 1); 

    // Set the API operation, version, and API signature in the request. 
    $nvpreq = "METHOD=$methodName_&VERSION=$version&PWD=$API_Password&USER=$API_UserName&SIGNATURE=$API_Signature".$nvpStr_; 

    //echo($nvpreq); 

    // Set the request as a POST FIELD for curl. 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $nvpreq); 

    // Get response from the server. 
    $httpResponse = curl_exec($ch); 

    if(!$httpResponse) { 
     exit("$methodName_ failed: ".curl_error($ch).'('.curl_errno($ch).')'); 
    } 

    // Extract the response details. 
    $httpResponseAr = explode("&", $httpResponse); 

    $httpParsedResponseAr = array(); 
    foreach ($httpResponseAr as $i => $value) { 
     $tmpAr = explode("=", $value); 
     if(sizeof($tmpAr) > 1) { 
      $httpParsedResponseAr[$tmpAr[0]] = $tmpAr[1]; 
     } 
    } 

    if((0 == sizeof($httpParsedResponseAr)) || !array_key_exists('ACK', $httpParsedResponseAr)) { 
     exit("Invalid HTTP Response for POST request($nvpreq) to $API_Endpoint."); 
    } 

    return $httpParsedResponseAr; 
} 

?> 
+0

Вы проверили свою историю IPN в своей учетной записи PayPal, чтобы убедиться, что она действительно отправляется из PayPal. Кроме того, если вы просматриваете сообщение IPN в своей истории, он должен предоставить вам код состояния, который возвращается, если он возвращается. –

+0

Я только что проверил историю IPN, и транзакция на самом деле есть! И его статус «отправлен». Я также пошел на developer.paypal.com и использовал симулятор IPN, но опять же моя программа не могла услышать IPN-хит. В чем проблема? Во время работы в среде песочницы у меня не было проблем. Это плохой URL? «http://www.zeej.com.sa/printshop/ipn.php» ... если у него не будет такого длинного пути или чего-то еще? – user961627

ответ

0

Проверяли ли вы журналы доступа к серверам и журналы ошибок, чтобы убедиться, что сценарий не является ошибкой? Сейчас есть некоторые проблемы с IPN, которые могут вызывать проблему yoru, которую вы видите. Я бы предложил открыть билет с PayPal's Merchant Technical Support, чтобы этот вопрос можно было изучить. Таким образом, вы также будете уведомлены, как только проблема будет решена.

1

Хорошо, я нашел проблему. Это не проблема с PayPal. Я пошел на страницу IPN www.mydomain.com/printshop/ipn.php, и PHP показал мне, что у меня была синтаксическая ошибка на странице ... , поэтому он не принимал никаких IPN-хитов, потому что он даже не работал! Исправлена ​​ошибка синтаксиса, и теперь я получаю обращения к IPN.