$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);
?>
|