4

PayPalIPNスクリプトから次の情報を受け取ります。以下から、IPNトランザクションが失敗する原因は明らかですか?そうでない場合、どうすれば問題をさらに調査できますか?

[01/25/2010 7:49 PM] - FAIL: IPN Validation Failed.
IPN $_POST variables from PayPal:
mc_gross=25.00
protection_eligibility=Ineligible
address_status=unconfirmed
payer_id=AEVB83JZKDRCL
tax=0.00
address_street=1 Main Terrace
payment_date=10:49:52 Jan 25, 2010 PST
payment_status=Pending
charset=windows-1252
address_zip=W12 4LQ
first_name=Test
address_country_code=GB
address_name=Test User
notify_version=2.9
custom=
payer_status=unverified
address_country=United Kingdom
address_city=Wolverhampton
quantity=1
verify_sign=A0I1KzEZadt6mIDXxQkkIQCQKPTMAGvCuZ8RKXsOCujIi.RoMxAnbZXi
payer_email=test1_1263505944_per@example.com
txn_id=38A45069EV5838100
payment_type=instant
last_name=User
address_state=West Midlands
receiver_email=martin@example.com
pending_reason=unilateral
txn_type=web_accept
item_name=Ultimate Challenge UK Ressurection  Standard Seating (25.00 GBP)
mc_currency=GBP
item_number=
residence_country=GB
test_ipn=1
handling_amount=0.00
transaction_subject=Ultimate Challenge UK Ressurection  Standard Seating (25.00 GBP)
payment_gross=
shipping=0.00


IPN response from PayPal server:
 HTTP/1.1 200 OK
Date: Mon, 25 Jan 2010 18:49:56 GMT
Server: Apache
Set-Cookie: cwrClyrK4LoCV1fydGbAxiNL6iG=_hMqg4cipUMV6RnPhXQ-05S5HEZk2hx2Yc87bjkBg5dZZLYqHTsxqiYwvU9Hjas5YeKTg9jnkbQYomER3_bjuAIW9f15003nc2FYPzIYqFuCc-Jfz1B8byXHhtrJ6OHyiPlmo0%7cGRbawzJR-iAiebJ1pZJZ3DzypAO4untXvofHa07UaqPHkeOZNQTSoCfMobgODGnxgP6jHW%7cf29zaCIP63s4TuzaT12cEiU-aih_kOHju4cqZ4KPV18bl-LTNlFzFLLGmr_DOhyXznq--m%7c1264445397; domain=.paypal.com; path=/
Set-Cookie: cookie_check=yes; expires=Thu, 23-Jan-2020 18:49:57 GMT; domain=.paypal.com; path=/
Set-Cookie: navcmd=_notify-validate; domain=.paypal.com; path=/
Set-Cookie: navlns=0; expires=Sun, 20-Jan-2030 18:49:57 GMT; domain=.paypal.com; path=/
Vary: Accept-Encoding
Keep-Alive: timeout=5, max=92
Connection: Keep-Alive
Transfer-Encoding: chunked
Content-Type: text/html; charset=UTF-8

7
INVALID
0
4

4 に答える 4

5

MicahCarrickによるPHPPaypalIPN統合クラスを使用していて、同じ問題を抱えている人は誰でも:IPN変数と値の前にcmd=_notify-validateを付ける必要があります。paypal.class.phpファイルでは、それは正反対です。

したがって、$post_string = '';179行目をreplaceで
$post_string="cmd=_notify-validate";
置き換えるだけです。
$post_string .= $field.'='.urlencode(stripslashes($value)).'&';

181行目$post_string .= '&' . $field.'='.urlencode(stripslashes($value));

次に、184行目を削除する$post_string.="cmd=_notify-validate";と、問題が解決するはずです。

于 2010-07-22T20:53:36.717 に答える
4

問題を調査するためにIPNテストツールを試しましたか?

これを使用して、送信するフォームを再現し、一貫した結果が得られるかどうかを確認できます。

失敗しているコンテキストを正確に指定すると、より適切な回答が得られる可能性があります。

于 2010-01-25T18:59:06.463 に答える
2

サンドボックスPaypalに接続するには、次の行を使用します。

$fp = fsockopen ('ssl://www.sandbox.paypal.com', 443, $errno, $errstr, 30); 

ではなく:$fp = fsockopen($url_parsed['host'],"80",$err_num,$err_str,30);

応答IPNは「VERIFIED」という単語を送信します

SSLを介してPaypalIPNをテストしている場合ssl://www.sandbox.paypal.comは、port 443

于 2012-07-02T13:07:05.930 に答える
0

@ドミニク、それは私の問題も解決するようです!私はたまたまMdEmranHasanのPHPクラスを使用していました。そして、この問題で約1週間私の髪を引き裂きました!

だから私の編集はこのように見えました...以前$postString .="cmd=_notify-validate"; //はwhileループの後でした!このコードは関数でラップされましたvalidateIPN

    $postString .= "cmd=_notify-validate"; // append ipn command

    foreach ($_POST as $field=>$value)
    {
        $this->ipnData["$field"] = $value;
        $postString .= '&' . $field .'=' . urlencode(stripslashes($value));
    }
于 2011-11-30T00:22:38.637 に答える