php は、curl を使用して discuz へのログインをシミュレートし、posting_PHP チュートリアルをシミュレートします

WBOY
リリース: 2016-07-20 11:14:44
オリジナル
959 人が閲覧しました

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


$post_fields = array();
//次の 2 つの項目は変更する必要はありません
$post_fields['loginfield'] = 'username';
$post_fields['loginsubmit'] = 'true';
/ /ユーザー名とパスワードを入力する必要があります
$post_fields['username'] = 'tianxin';
$post_fields['password'] = '111111';
//セキュリティの質問
$post_fields['questionid'] = 0 ;
$post_fields['answer'] = '';
//@todo 確認コード
$post_fields['seccoverify'] = '';

//フォームを取得します
$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];
} else {
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); 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); exec ($ch);

curl_close($ch);


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

}



$post_data = array();
//投稿タイトル
$post_data['subject'] = 'test2';
//投稿内容
$post_data['message'] = 'test2';

$post_data[' topicsubmit'] = "yes";

$post_data['extra'] = '';
//投稿タグ
$post_data['tags'] = 'test';
//投稿のハッシュコード、これは非常に批判的です!このハッシュ コードが見つからない場合、discuz は、アクセス元のページが間違っていることを警告します
$post_data['formhash']=$formhash;
C $ ch =curlopt_init ($ send_url);
CURL_SETOPT ($ ch,curlopt_referr, $ send_url); // リファラーを偽装します
curl_setopt ($ ch,curlopt_returntransfer, 0); $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 ファイルをクリーンアップ
unlink($cookie_file);

?>




http://www.bkjia.com/PHPjc/440268.html

www.bkjia.com


tru​​e

http://www.bkjia.com/PHPjc/440268.html

技術記事

?php $discuz_url = 'http://127.0.0.1/discuz/';//フォーラムのアドレス $login_url = $discuz_url .'logging.php?action=login';//ログインページのアドレス $post_fields = array(); //次の 2 つの項目は修復する必要はありません...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート