ホームページ  >  記事  >  バックエンド開発  >  Php CURL はフォーラムへのログインをシミュレートし、データを収集します。 example_PHP チュートリアル

Php CURL はフォーラムへのログインをシミュレートし、データを収集します。 example_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 10:48:39916ブラウズ

この記事では、Php CURL 模擬ログイン フォーラムとデータ収集の例について学生に紹介します。curl 模擬ログイン機能の使用に興味がある場合は、参考として入力してください。

Web サイトにアクセスするブラウザをシミュレートするには、最初のステップは、ブラウザが http メッセージをどのように送信するか、Web サイト サーバーがブラウザにどのようなコンテンツを返すかを観察することです。外国人が開発した httpwatch ソフトウェアをインストールすることをお勧めします。クラック版を入手するのが最善です。そうしないと、一部の機能が使用できなくなります。このソフトウェアをインストールすると、IE に埋め込まれ、アドレス バーに URL を入力して Enter キーを押すと、ブラウザとサーバー間のすべての通信がスキャンされ、明確なビューが表示されます。このソフトウェアの使用方法については、この記事では紹介しません。

ブラウザー ログイン アプリケーション開発をシミュレートする際の最も重要なポイントは、ログイン検証を突破することです。 CURL テクノロジーは http だけでなく https もサポートします。違いは、SSL 暗号化送信の追加層があることです。 https Web サイトにログインしたい場合は、PHP が openssl をサポートしている必要があります。まず分析する例を見てみましょう。

コードは次のとおりです コードをコピー

$discuz_url = 'http://127.0.0.1/discuz/' //フォーラムのアドレス
; $login_url = $discuz_url . 'logging.php?action=login'; // ログインページのアドレス

$post_fields = array();
//次の 2 つの項目は変更する必要はありません
$post_fields['ログインフィールド'] = 'ユーザー名';
$post_fields['loginsubmit'] = 'true';
//ユーザー名とパスワードは必ず入力してください
$post_fields['ユーザー名'] = '天新';
$post_fields['パスワード'] = '111111';
//秘密の質問
$post_fields['questionid'] = 0;
$post_fields['answer'] = '';
//@todo 確認コード
$post_fields['seccoverify'] = '';

//FORMHASH フォームを取得
$ch =curl_init($login_url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
$contents =curl_exec($ch);
curl_close($ch);
preg_match('//i', $contents, $matches);
if (!empty($matches)) {
$formhash = $matches[1];
} その他 {
Die('フォーラムハッシュが見つかりません。');
}

//データをPOSTし、COOKIEを取得して、Webサイトの一時ディレクトリにCookieファイルを置きます
$cookie_file = tempnam('./temp', 'cookie');

$ch =curl_init($login_url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_fields);
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);
curl_exec($ch);
curl_close($ch);

//キーの Cookie ファイルを取得した後、その Cookie ファイルを使用して投稿をシミュレートできます。fid はフォーラムの列 ID です
$send_url = $discuz_url . "post.php?action=newthread&fid=2";


$ch =curl_init($send_url);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
$contents =curl_exec($ch);
curl_close($ch);

//ここでのハッシュ コードは、ログイン ウィンドウのハッシュ コードとは異なります。ここでの非表示には追加の id 属性があります
。 preg_match('//i', $contents, $一致);
if (!empty($matches)) {
$formhash = $matches[1];
} その他 {
Die('フォーラムハッシュが見つかりません。');
}


$post_data = array();
//投稿タイトル
$post_data['subject'] = 'test2';
//コンテンツを投稿します
$post_data['メッセージ'] = 'test2';
$post_data['topicsubmit'] = "はい";
$post_data['extra'] = '';
//タグを投稿します
$post_data['tags'] = 'テスト';
//投稿のハッシュ コード、これは非常に重要です。このハッシュ コードが見つからない場合、discuz は、アクセス元のページが間違っていることを警告します
$post_data['formhash'] = $formhash;


$ch =curl_init($send_url);
curl_setopt($ch, CURLOPT_REFERER, $send_url); //REFERER を偽装します
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);
$contents =curl_exec($ch);
curl_close($ch);

//Cookie ファイルをクリーンアップします
リンク解除($cookie_file);
?>

CURL实现网站模拟登陆

代码如下 复制幣

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/632770.html技術記事この文章は、curl 模擬登録機能を利用する場合に興味がある場合は、Php CURL 模擬登録ブロックとデータ サンプルの採用について、以下に記載されています。
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。