教程集 www.jiaochengji.com
教程集 >  脚本编程  >  php  >  正文 php中用curl模拟登录discuz以及模拟发帖

php中用curl模拟登录discuz以及模拟发帖

发布时间:2016-12-03   编辑:jiaochengji.com
教程集为您提供php中用curl模拟登录discuz以及模拟发帖等资源,欢迎您收藏本站,我们将为您提供最新的php中用curl模拟登录discuz以及模拟发帖资源
本文章完美的利用了php的curl功能实现模拟登录discuz以及模拟发帖,本教程供参考学习哦。
<table width="620" align="center" border="0" cellpadding="1" cellspacing="1" style="background:#FB7"> <tr> <td width="464" height="27" bgcolor="#FFE7CE"> 代码如下</td> <td width="109" align="center" bgcolor="#FFE7CE" style="cursor:pointer;" onclick="doCopy('copy9759')">复制代码</td> </tr> <tr> <td height="auto" colspan="2" valign="top" bgcolor="#FFFFFF" style="padding:10px;" class="copyclass" id=copy9759>

<?php

$discuz_url = ‘http://localhost/klive/root/Discuz_X2.5_SC_GBK/’;//论坛地址
$login_url = $discuz_url .’member.php?mod=logging&action=login’;//登录页地址

$post_fields = array();
//以下两项不需要修改
$post_fields['loginfield'] = ‘username’;
$post_fields['loginsubmit'] = ‘true’;
//用户名和密码,必须填写
$post_fields['username'] = ‘admin’;
$post_fields['password'] = ‘admin’;
//安全提问
$post_fields['questionid'] = 0;
$post_fields['answer'] = ”;
//@todo验证码
$post_fields['seccodeverify'] = ”;

//获取表单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(‘/<inputs*type=”hidden”s*name=”formhash”s*value=”(.*?)”s*/>/i’, $contents,

$matches);
if(!empty($matches)) {
$formhash = $matches[1];
} else {
die(‘Not found the forumhash.’);
}

//POST数据,获取COOKIE,cookie文件放在网站的temp目录下
$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.”forum.php?mod=post&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);
//这里的hash码和登陆窗口的hash码的正则不太一样,这里的hidden多了一个id属性
preg_match(‘/<inputs*type=”hidden”s*name=”formhash”s*id=”formhash”s*value=”(.*?)”s*/>/i

’, $contents, $matches);
if(!empty($matches)) {
$formhash = $matches[1];
} else {
die(‘Not found the forumhash.’);
}

$post_data = array();
//帖子标题
$post_data['subject'] = ‘test2′;
//帖子内容
$post_data['message'] = ‘test2′;
$post_data['topicsubmit'] = “yes”;
$post_data['extra'] = ”;
//帖子标签
$post_data['tags'] = ‘test’;
//帖子的hash码,这个非常关键!假如缺少这个hash码,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文件
unlink($cookie_file);

?>

您可能感兴趣的文章:
PHP CURL获取cookies模拟登录的方法介绍
php curl模拟登录discuz并模拟发帖的实现方法
php curl模拟post请求的例子
php中用curl模拟登录discuz以及模拟发帖
php curl采集Discuz的代码实例
Php CURL模拟登陆论坛并采集数据实例
php模拟登录qq邮箱(curl命令详解)
php curl_init函数用法举例
php curl采集站外内容示例代码
php模拟远程登录示例代码

[关闭]
~ ~