1

PayPalのサンドボックスで完全にテストし、プロセスを完全に機能させた後。私はそれをライブで撮りましたが、機能していません。

notify_urlを介してPayPalからPOSTデータを受信して​​います。次に、データの前にcmd=_notify-validateを付けてPayPalに送り返します。

PayPalの文書化されたコードを使用して、これを使用してメッセージをPayPalに送信しています。

$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 ('ssl://www.paypal.com', 443, $errno, $errstr, 30);

(このコードを使用して応答を取得します)

$res = stream_get_contents($fp, 1024);

私が戻ってきた応答は次のとおりです。

HTTP / 1.1 200 OK
日付:2012年5月11日金曜日20:51:28 GMT
Xフレーム-オプション:SAMEORIGIN
Set-Cookie:cwrClyrK4LoCV1fydGbAxiNL6iG = SdeBuKBN39mjr3w791CHr_MlSkoBdDmbxpQOjT_WOicyD_Sg6BYZm8koiEv2-5XBUkCjpXQwFqIxIQgIyo3e7arO8015CVw96dpne2CNjbgc1CvpDlqXn72IBWq%7cW7uYn6Za7ljG4iLtLVcyFoPk8gZD7sr_S8WjwZrZWD8UXzE7KAH3bll9TVik3wbdCFlrZG%7csxrZZHSH5SWBGfrKsIU6Dz-K43j4h37efIkWFcVJVER0ncRxNJ0wANN1Dp3pZpV2PLxC1m%7c1336769488。domain = .paypal.com; パス=/; 安全; HttpOnly
Set-Cookie:cookie_check = yes; 期限切れ=月、2022年5月9日20:51:28 GMT; domain = .paypal.com; パス=/; 安全; HttpOnly
Set-Cookie:navcmd = _notify-validate; domain = .paypal.com; パス=/; 安全; HttpOnly
Set-Cookie:navlns = 0.0; 有効期限=木、2032年5月6日20:51:28 GMT; domain = .paypal.com; パス=/; 安全; HttpOnly
Set-Cookie:Apache = 10.73.8.50.1336769488653443; パス=/; Expires = Sun、04-May-42 20:51:28 GMT
変更:Accept-エンコーディング
Strict-Transport-Security:max-age = 14400
接続:閉じる
コンテンツタイプ:text / html; charset = UTF-8
Set-Cookie:TSe9a623 = bb3c8ce40a7f3f6d1c018255c9

私が得ていないのは、これでの無効または検証済みの応答です。これはPayPalからの出力全体です。サンドボックスでは、最後の行でVERIFIEDを取得しており、Set-Cookieは取得していませんでした。

INVALIDまたはVERIFIEDの応答がないのは奇妙に思えます。

任意の提案をいただければ幸いです。

4

1 に答える 1

1

fwrite / fputsを使用してソケットにリクエストを書き込みましたか?また、その応答の長さから判断すると、ストリームから1024バイト以上を読み取る必要がある場合があります。それはひどく近づいています。

ループで応答を読みたい場合があります。

$resp = '';
while (!feof($fp)) {
    $resp .= stream_get_contents($fp, 1024);
}

次に、以下を使用してヘッダーを本文から分離できます。

list($headers, $response) = explode("\r\n\r\n", 2);
于 2012-05-11T21:26:19.070 に答える