http://www.domain.com/profile
などのページにアクセスしようとしています。アクションURLとログインURLは同じで、認証のためにクッキーをhttp://www.example.com/cookies.txt
に保存しようとしています。ここで私が使用しているコードは次のとおりです。クッキーでcURL PHPリクエストが行われた場合の不正アクセス
$loginURL = 'http://www.domain.com/login';
$COOKIE_FILE = 'http://wwww.example.com/cookies.txt';
$postValues = array(
'username' => 'myusername',
'password' => 'mypassword'
);
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, $loginURL);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, http_build_query($postValues));
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_COOKIEJAR, $COOKIE_FILE);
curl_setopt($curl, CURLOPT_USERAGENT, 'Chrome/35.0.2309.372');
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_REFERER, $loginURL);
curl_setopt($curl, CURLOPT_FOLLOWLOCATION, true);
curl_exec($curl);
if(curl_errno($curl)){throw new Exception(curl_error($curl));}
// now we are logged in, attempt to access a password-protected page
curl_setopt($curl, CURLOPT_URL, 'http://www.domain.com/profile');
curl_setopt($curl, CURLOPT_COOKIEJAR, $COOKIE_FILE);
curl_setopt($curl, CURLOPT_USERAGENT, USER_AGENT);
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, false);
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
echo curl_exec($curl);
カールの要求が成功しているように思えるが、私は、「不正アクセス」を言って、サーバーからページをエコー取得しています。私のクッキーシステムは正しく動作しているとは思わない?それをどうやって確認できますか?どうすれば修正できますか?
私はこれを試しましたが、うまくいきませんでした。 'echo file_get_contents($ COOKIE_FILE)'で$ COOKIE_FILEの内容を見ることができるはずですが、空白です。 – Wagtail
クッキーデータを送信しないことの意味を説明できますか?どうすればいい? – Wagtail
私はちょうど最初の文章を言い換えようとしました。ファイルから読み取るにはクッキーファイルが必要です。しかし、なぜファイルを作成できないのかわかりません。たぶん、まずローカルファイルを試してみてください。または、CURLOPT_VERBOSEをCURLOPT_STDERRと組み合わせて使用します。 – jh1711