博客导读网 |
一个让你随便看看的地方 |
使用PHP模拟登录QQ邮箱获取QQ好友列表推荐记录人生轨迹,寻找人生航向! |
||
|
转载:http://www.javaeye.com/topic/375434 <?php /** * @file class.qqhttp.php * qq邮箱登陆获取类 * @author wc<cao8222@gmail.com> * @date 2009-04-27 */ class QQHttp { var $cookie = ''; function __cunstrut() { } function makeForm() { $form = array( 'url' => "http://mail.qq.com/cgi-bin/loginpage", ); $data = $this->curlFunc($form); preg_match('/name="ts"\svalue="(\d+)"/',$data['html'], $tspre); $ts = $tspre[1]; preg_match('/action="http:\/\/(m\d+)\.mail\.qq\.com/',$data['html'], $server); $server_no = $server[1]; /* login.html 载入 */ $html = file_get_contents(dirname(__FILE__).'/login.htm'); $html = str_replace('{_ts_}',$ts, $html); $html = str_replace('{_server_no_}',$server_no, $html); return $html; } function curlFunc($array) { $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $array['url']); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); if( isset($array['header']) && $array['header'] ) { curl_setopt($ch, CURLOPT_HEADER, 1); } if(isset($array['httpheader'])) { curl_setopt($ch, CURLOPT_HTTPHEADER, $array['httpheader']); } if(isset($array['referer'])) { curl_setopt($ch, CURLOPT_REFERER, $array['referer']); } if( isset($array['post']) ) { curl_setopt($ch, CURLOPT_POST, 1 ); curl_setopt($ch, CURLOPT_POSTFIELDS, $array['post']); } if( isset($array['cookie']) ){ curl_setopt($ch, CURLOPT_COOKIE, $array['cookie']); } $r['erro'] = curl_error($ch); $r['errno'] = curl_errno($ch); $r['html'] = curl_exec($ch); $r['http_code'] = curl_getinfo($ch, CURLINFO_HTTP_CODE); curl_close($ch); return $r; } /** * 获取验证码图片和cookie * @param Null * * @return array('img'=>String, 'cookie'=>String) */ function getVFCode () { $vfcode = array( 'header' => true, 'cookie' => false, 'url'=>'http://ptlogin2.qq.com/getimage?aid='.$_GET['aid'].'&'.@$_GET['t'], ); $r = $this->curlFunc($vfcode); if ($r['http_code'] != 200 ) return false; $data = split("\n", $r['html']); preg_match('/verifysession=([^;]+);/',$data[5], $temp); $cookie = trim($temp[1]); $img = $data[9]; return array('img'=>$img,'cookie'=>$cookie); } /** * 登陆qq邮箱 * * @param $cookie getvfcode中生成的cookie * * @return array( * sid=>String , //用户认证的唯一标示 * login => Boolean, //true 登陆成功 ,false 登陆失败 * server_no => String // 服务器编号 * active => Boolean //true 已开通 ,false 未开通 邮箱 * cookie => String // 获取数据cookie * * ); */ function login($cookie) { /* 生成参数字符串 */ $post = array(); foreach($_POST as $k => $v) { $post[] = $k.'='.urlencode($v); } $poststr = implode('&',$post); $r['server_no'] = $_GET['server_no']; $login = array( 'url'=>'http://'.$r['server_no'].'.mail.qq.com/cgi-bin/login?sid=0,2,zh_CN', 'header' => true, 'cookie' => 'verifysession='.$cookie, 'referer' => 'http://mail.qq.com/cgi-bin/loginpage', 'httpheader'=>array( "Host: " . $r['server_no'] . '.mail.qq.com', "User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.0.9) Gecko/2009040821 Firefox/3.0.9 FirePHP/0.2.4", "Content-Type: application/x-www-form-urlencoded", ), 'post' => $poststr , ); $data = $this->curlFunc($login); $data['html'] = iconv("gb2312", "UTF-8", $data['html']); if ($data['http_code'] != 200) { $this->error($data); return false; } /* 测试数据 */ //$data['html'] =file_get_contents('./r.txt'); $r['uin'] = $_POST['uin']; /* 登陆错误的判断 */ if (preg_match('|errtype=(\d)|', $data['html'], $temp_err)) { $r['login'] = false; if ($temp_err[1] == 1) { $r['msg'] = '账号和密码错误'; } elseif ($temp_err[1] == 2) { $r['msg'] = '验证码错误'; } return $r; } /* 登陆成功 */ preg_match('|urlHead="([^"]+)"|i',$data['html'],$temp_url); $urlhead = $temp_url[1]; if (preg_match('|frame_html\?sid=([^"]+)"|i',$data['html'],$temp_sid) ) { $r['sid'] = $temp_sid[1]; $r['active'] = true; } elseif (preg_match('|autoactivation\?sid=([^&]+)?&|i',$data['html'],$temp_sid) ) { $r['sid'] = $temp_sid[1]; $r['active'] = false; } /* 登录后cookie的获取 ,在后续操作中用到 */ if (preg_match_all('|Set-Cookie:([^=]+=[^;]+)|i', $data['html'], $new_cookies) ) { $cookiestr = implode('; ', $new_cookies[1]); $cookiestr .= '; verifysession='.$cookie; } $r['login'] = true; $r['cookie'] = $cookiestr; return $r; } function openEmail($param) { $openEmail = array( 'url'=>'http://'.$param['server_no'].'.mail.qq.com/cgi-bin/autoactivation?actmode=6&sid='.$param['sid'], 'header' => true, 'cookie' => $param['cookie'], 'referer' => 'http://'.$param['server_no'].'mail.qq.com/cgi-bin/autoactivation?sid='.$param['sid'].'&action=reg_activate&actmode=6', 'httpheader'=>array( "Host: " . $param['server_no'] . '.mail.qq.com', 'Accept-Charset: gb2312,utf-8;q=0.7,*;q=0.7', "User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.0.9) Gecko/2009040821 Firefox/3.0.9 FirePHP/0.2.4", ), ); $data = $this->curlFunc($openEmail); if (preg_match('|Set-Cookie:qqmail_activated=0|i', $data['html'])) { $param['active'] = true; $param['cookie'] = $param['cookie'] .'; qqmail_activated=0; qqmail_alias='; } return $param; } /** * * 获取friends数据 * * @param $param = array( * sid=>String , //用户认证的唯一标示 * login => Boolean, //true 登陆成功 ,false 登陆失败 * server_no => String // 服务器编号 * active => Boolean //true 已开通 ,false 未开通 邮箱 * cookie => String // 获取数据cookie * * ); * @return Array( * key=>value, // key:qq号,value: nickname * ); */ function getFriends($param) { $friend = array( 'url'=>'http://'.$param['server_no'].'.mail.qq.com/cgi-bin/addr_listall?type=user&&category=all&sid='.$param['sid'], 'header' => true, 'cookie' => $param['cookie'], 'referer' => 'http://m151.mail.qq.com/cgi-bin/addr_listall?sid='.$param['sid'].'&sorttype=null&category=common', 'httpheader'=>array( "Host: " . $param['server_no'] . '.mail.qq.com', 'Accept-Charset:utf-8;q=0.7,*;q=0.7', "User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.0.9) Gecko/2009040821 Firefox/3.0.9 FirePHP/0.2.4", ), ); $r = $this->curlFunc($friend); if ($r['http_code'] != 200) { $this->error($r); return false; } $data = $r['html']; $preg = preg_match_all('|<p class="L_n"><span><img class="L_q" name=qqplusimg key="(\d+)"[^>]+/> ([^<]+)</span></p>|i', $data, $temp_list); if ($preg == 0) return array(); $list = array_combine($temp_list[1],$temp_list[2]); return $list; } /** * 错误显示 * * @param $str array * * @return */ function error($str) { $str['html'] = str_replace('script','', $str['html']); var_dump($str); exit; } } ?> |
||
| 原文地址:http://chenling1018.blog.163.com/blog/static/1480254201021563746803 |
| © 2010 博客导读网 BlogABC.NET 本站所有内容皆由网友推荐而来,所有博文的版权归原作者所有,如有冒犯,请邮件告知。uncracker#gmail.com |