2011-08-14 25 views
1

私はPHPで書かれたPayPal IPNスクリプトを持っていますが、私が何を試してもそれを動作させることはできません。PayPal IPN returns Invalid

PayPalはPayPalサンドボックス& PayPal IPNシミュレータを使用して「INVALID」を返します。私はまだそれを生きて試してみましたが、おそらく同じものを返すでしょう。

<?php 
/// 
// read the post from PayPal system and add 'cmd' 
    $req = 'cmd=_notify-validate'; 
    // Are we using magic quotes? 
    $get_magic_quotes_exists = false; 
    if(function_exists('get_magic_quotes_gpc')){ 
      $get_magic_quotes_exists = true; 
    } 
    foreach($_POST as $key => $value){ 
     // Handle escape characters, which depends on setting of magic quotes 
     if($get_magic_quotes_exists == true && get_magic_quotes_gpc() == 1){ 
      $value = urlencode(stripslashes($value)); 
     }else{ 
      $value = urlencode($value); 
     } 
     if($get_magic_quotes_exists && get_magic_quotes_gpc() == 1){ 
      $req .= '&' . $key . '=' . urlencode(stripslashes(html_entity_decode($value, ENT_COMPAT, 'windows-1252'))); 
      $dc .= '&' . $key . '=' . urlencode(stripslashes(html_entity_decode($value, ENT_COMPAT, 'windows-1252'))); 
      $emailtext .= "\n" . $key . "=" . urlencode(stripslashes(html_entity_decode($value, ENT_COMPAT, 'windows-1252'))); 
     }else{ 
      $req .= '&' . $key . '=' . urlencode(html_entity_decode($value, ENT_COMPAT, 'windows-1252')); 
      $dc .= '&' . $key . '=' . urlencode(html_entity_decode($value, ENT_COMPAT, 'windows-1252')); 
      $emailtext .= "\n" . $key . "=" . urlencode(html_entity_decode($value, ENT_COMPAT, 'windows-1252')); 
     } 
    } 
    /*// post back to PayPal system to validate 
    $header .= "POST /cgi-bin/webscr HTTP/1.0\r\n"; 
    $header .= "Content-Type: application/x-www-form-urlencoded\r\n"; 
    $header .= "Content-Length: " . strlen($req) . "\r\n\r\n"; 
    $fp = fsockopen('www.sandbox.paypal.com', 80, $errno, $errstr, 30);*/ 
    // CURL 
    $ch = curl_init('https://www.sandbox.paypal.com/cgi-bin/webscr'); 
    curl_setopt($ch, CURLOPT_POST, 1); 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $req); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    curl_setopt($ch, CURLOPT_HTTPHEADER, array("Content-Type: application/x-www-form-urlencoded", "Content-Length: " . strlen($req))); 
    curl_setopt($ch, CURLOPT_HEADER, false); 
    curl_setopt($ch, CURLOPT_VERBOSE, 1); 
    curl_setopt($ch, CURLOPT_TIMEOUT, 30); 
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); 
    $res = curl_exec($ch); 
    if(curl_error($ch)) { 
     $last_error = 'Could not connect to CURL'; 
    } 
    curl_close($ch); 
    // Write to log... 
    $myFile = "log.txt"; 
    $fh = fopen($myFile, 'w'); 
    $stringData = "IPN REQUEST\n\n$req"; 
    fwrite($fh, $stringData); 
    $stringData = "\n\nIPN RESPONSE:\n\n$res"; 
    fwrite($fh, $stringData); 
    fclose($fh); 
    if(strcmp($res, 'VERIFIED') == 0){ 
     // check the payment_status is Completed 
     if($payment_status != 'Completed'){ 
      $last_error = "Payment was not completed."; 
      //exit($last_error); 
    } 

私はCURLとFsockopenの両方を試しました。 OpenSSLはサーバー上で有効になっています。ここで

が戻ってPayPalにポストされたデータのサンプルです:

cmd=_notify-validate&test_ipn=1&payment_type=instant&payment_date=12%253A06%253A49%2BAug%2B14%252C%2B2011%2BPDT&payment_status=Completed&address_status=confirmed&payer_status=verified&first_name=Peter&last_name=Anderson&payer_email=paypal2.test%2540gmail.com&payer_id=TESTBUYERID01&address_name=John%2BSmith&address_country=United%2BStates&address_country_code=US&address_zip=95131&address_state=CA&address_city=San%2BJose&address_street=123%252C%2Bany%2Bstreet&business=dr.pa%2540custcarecentral.com&receiver_email=paypal.test%2540custcarecentral.com&receiver_id=TESTSELLERID1&residence_country=US&item_name=something&item_number=1&quantity=1&shipping=0&tax=0&mc_currency=USD&mc_fee=0&mc_gross=9.95&mc_gross_1=9.95&txn_type=web_accept&txn_id=49814196&notify_version=2.1&custom=xyz123&charset=windows-1252&verify_sign=A6PXLu.ocjeCd4T66jio.zEQRv65AD4orMH3FTVR7QibqBGYTnYA8ToF 

Fsock 1私はこの1つ別のサーバー上で働いてみましたが、いませんでした。

誰でも手伝ってもらえますか?私は本当にこれ以上の忍耐を失い始めている。事前

+1

比較対象となる既知のIPN検証スクリプトhttp://www.scriptdevelopers.net/download/paypal_ipn_class.zip –

+0

ありがとうございます。あなたが投稿したスクリプトは、(PayPalのURLはサンドボックスには間違っていますが)動作します。それが正しいこと、鉱山が機能しない理由を見ていきます。 – Peter

+0

もう一度見て...あなたは$ valueにurlencode()を2回呼び出していますか? –

答えて

0

おかげであなたはPHP-PayPal-IPNを試してみたいことがあります。それはかなりシンプルで、エラー処理をかなり理解しやすいPayPalへの投稿を担当します。 SSL/HTTPとfsockopen/cURLを選択できます。

あなたのコードは次のようになります。

ini_set('log_errors', true); 
ini_set('error_log', dirname(__FILE__).'/ipn_errors.log'); 

include('ipnlistener.php'); 
$listener = new IpnListener(); 
$listener->use_sandbox = true; 

try { 
    $verified = $listener->processIpn(); 
} catch (Exception $e) { 
    error_log($e->getMessage()); 
    exit(0); 
} 

if ($verified) { 
    // TODO: Implement additional fraud checks and MySQL storage 
    mail('YOUR EMAIL ADDRESS', 'Valid IPN', $listener->getTextReport()); 
} else { 
    // manually investigate the invalid IPN 
    mail('YOUR EMAIL ADDRESS', 'Invalid IPN', $listener->getTextReport()); 
} 

あなたが働いたIPNのエラー(ペイパルから無効なHTTP応答コードのような)ハードエラーログやメールをチェックします。あなたはまた、いくつかのアイデアのためのソースを見ることができます。

私はあなたのhtml_entity_decode()の使用についてちょっと不思議です。どのタイプのサーバーを実行していますか?