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の応答がないのは奇妙に思えます。
任意の提案をいただければ幸いです。