用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php利用CURL函数登入163邮箱并获取自己的通讯录

时间:2015-01-23  来源:西部数据  作者:西部数据

我们使用phpmailer登录邮件发邮件也是使用了curl原理来实现模仿用户(www.phpfensi.com)发邮件了,今天看了两个利用CURL函数登入163邮箱并获取自己的通讯录的例子.

学习了一些CURL的基础知识并做了这个示例,关于CURL的知识可以从php的官网上查看,点击查看.

示例代码调试方式:把$userName和$password换成自己163邮箱的用户名和密码即可.

注意:用户名和密码一定要正确,否则报错,没有做容错处理,示例代码如下:

  1. <?php 
  2. //==================账号信息================== 
  3. //用户名 
  4. $userName = 'xxxxxxxx'
  5. //密码 
  6. $password = 'xxxxxxxx'
  7. //邮箱 
  8. $email = $userName . '@163.com'
  9. //==================登录================== 
  10. //登录地址(登录地址并不是form表单设置的地址,通过js修改了form的action属性,需要查看登录页面源码才能发现) 
  11. $loginUrl = "https://ssl.mail.163.com/entry/coremail/fcg/ntesdoor2?df=mail163_letter&from=web&funcid=loginone&iframe=1&language=-1&passtype=1&product=mail163&net=n&style=-1&race=-2_56_-2_hz&uid={$email}"
  12. //登录时发送的post数据(查看form表单,注意有隐藏域) 
  13. $postArray = array
  14.     "url2" => "http://mail.163.com/errorpage/error163.htm"
  15.     "savelogin" => 0,  "username" => trim($userName), "password" => $password
  16. ); 
  17. $postString = ''
  18. foreach($postArray as $key => $value){ 
  19.     $postString .= "{$key}={$value}&"
  20. $postString = trim($postString'&'); 
  21. //初始化CURL对象 
  22. $curl = curl_init(); 
  23. //设置请求地址 
  24. curl_setopt($curl, CURLOPT_URL, $loginUrl); 
  25. //禁用后CURL将终止从服务端进行验证 
  26. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE); 
  27. //启用时将获取的信息以文件流的形式返回,而不是直接输出 
  28. curl_setopt($curl, CURLOPT_RETURNTRANSFER, TRUE); 
  29. //启用时会将头文件的信息作为数据流输出 
  30. curl_setopt($curl, CURLOPT_HEADER, TRUE); 
  31. //设置POST参数 
  32. curl_setopt($curl, CURLOPT_POST, TRUE); 
  33. curl_setopt($curl, CURLOPT_POSTFIELDS, $postString); 
  34. //执行给定的CURL会话 
  35. //成功时返回 TRUE,失败时返回 FALSE 
  36. //然而,如果 CURLOPT_RETURNTRANSFER选项被设置,函数执行成功时会返回执行的结果,失败时返回 FALSE 
  37. $html = curl_exec($curl); 
  38. //把获取到的数据写入文件中以便查看 
  39. //file_put_contents('temp1.txt', $html); 
  40. //分割头文件和内容 
  41. list($head$content) = explode("\r\n\r\n"$html, 2); 
  42. //把获取到的数据写入文件中以便查看 
  43. //file_put_contents('temp2.txt', $head); 
  44. //file_put_contents('temp3.txt', $content); 
  45. $head = explode("\r\n"$head); 
  46. //获取cookie信息 
  47. $cookieString = ''
  48. foreach ($head as $value){ 
  49.     if(stripos($value"Set-Cookie: ") !== false){ 
  50.         $cookieString .= str_replace("Set-Cookie: """$value); 
  51.     } 
  52. //从content里分析出sid值(读取通讯录信息的参数) 
  53. $startString = 'top.location.href = "'
  54. $endString = '";</script>'
  55. $start = strpos($content$startString); 
  56. $end = strpos($content$endString); 
  57. $tempUrl = substr($content$start + strlen($startString), $end - $start - strlen($startString)); 
  58. $tempUrlVals = parse_url($tempUrl); 
  59. parse_str($tempUrlVals['query'], $queryVals); 
  60. $sid = $queryVals['sid']; 
  61. //==================读取邮箱================== 
  62. //读取邮箱地址 
  63. $readUrl = "http://twebmail.mail.163.com/contacts/call.do?uid={$email}&sid={$sid}&from=webmail&cmd=newapi.getContacts&vcardver=3.0&ctype=all&attachinfos=yellowpage"
  64. //设置请求地址 
  65. curl_setopt($curl, CURLOPT_URL, $readUrl); 
  66. //设置POST参数 
  67. curl_setopt($curl, CURLOPT_POST, TRUE); 
  68. curl_setopt($curl, CURLOPT_POSTFIELDS, 'order=[{"field":"N","desc":"false"}]'); 
  69. //注意这里要设置从登录操作中获取的cookie 
  70. curl_setopt($curl, CURLOPT_COOKIE, $cookieString); 
  71. //禁用头文件输出 
  72. curl_setopt($curl, CURLOPT_HEADER, FALSE); 
  73. //执行给定的CURL会话 
  74. //成功时返回 TRUE,失败时返回 FALSE 
  75. //然而,如果 CURLOPT_RETURNTRANSFER选项被设置,函数执行成功时会返回执行的结果,失败时返回 FALSE 
  76. $content = curl_exec($curl); 
  77. //把获取到的数据写入文件中以便查看 
  78. //file_put_contents('temp4.txt', $content); 
  79. (www.phpfensi.com)//关闭一个CURL会话,并释放资源 
  80. curl_close($curl); 
  81. echo '<pre>'
  82. print_r(json_decode($content, true)); 
  83. echo '</pre>'

例子二,这个更高级一些可以输入信息,代码如下:

  1. <html> 
  2. <head> 
  3. <meta content="text/html; charset=utf-8" http-equiv="Content-Type"/> 
  4. <title>登陆163邮箱</title> 
  5. </head> 
  6. <body> 
  7. <form id="login" action="mail.php" method="POST"
  8. <label for="username">用户名:</label><input id="username" name="username" type="text" /> 
  9. <label for="password">密码:</label><input id="password" name="password" type="password" /> 
  10. <input type="submit" value="取得通讯录列表" /> 
  11. </form> 
  12. </body> 
  13. </html> 

mail.php,代码如下:

  1. <?php 
  2.     define("COOKIEJAR",ini_get"upload_tmp_dir" ).DIRECTORY_SEPARATOR."cookie.txt"); 
  3.      
  4.     if( !isset($_POST['username']) || !isset($_POST['username']) ){ 
  5.         echo 'ERROR QUEST'
  6.         exit(); 
  7.     } 
  8.      
  9.     $username = $_POST['username']; 
  10.     $pos = strrpos($username,'@'); 
  11.     if($pos === false){ 
  12.         $username .= "@163.com"
  13.     } 
  14.     $password = $_POST['password']; 
  15.      
  16.     //登陆163邮箱,获得登陆后的cookie 
  17.     $options = array
  18.       CURLOPT_URL => "https://reg.163.com/logins.jsp"
  19.       CURLOPT_SSL_VERIFYPEER => false, 
  20.       CURLOPT_POST => 1, 
  21.       CURLOPT_POSTFIELDS => "username=".$username."&password=".$password
  22.       CURLOPT_COOKIEJAR => COOKIEJAR, 
  23.     ); 
  24.     curl_quest($options); 
  25.      
  26.     //利用上一步获得的cookie进一步取得cookie 
  27.     $options2 = array
  28.       CURLOPT_URL => "http://fm163.163.com/coremail/fcg/ntesdoor2?verifycookie=1&lightweight=1"
  29.       CURLOPT_COOKIEFILE => COOKIEJAR, 
  30.       CURLOPT_COOKIEJAR => COOKIEJAR, 
  31.     ); 
  32.     curl_quest($options2); 
  33.      
  34.     //分析cookie文件,取得coremail. 
  35.     $cookiefile = file_get_contents(COOKIEJAR); 
  36.     preg_match('|Coremail.*?%(\S*)|',$cookiefile,$sid); 
  37.      
  38.     //发送获得通讯录xml请求. 
  39.     $postStr3 = '<?xml version="1.0"?><object><array name="items"><object><string name="func">pab:searchContacts</string 
  40. ><object name="var"><array name="order"><object><string name="field">FN</string><boolean name="ignoreCase" 
  41. >true</boolean></object></array></object></object><object><string name="func">user:getSignatures</string 
  42. ></object><object><string name="func">pab:getAllGroups</string></object></array></object>'; 
  43.     $options3 = array
  44.        CURLOPT_URL => 'http://eg1a120.mail.163.com/a/s?sid='.$sid[1].'&func=global:sequential'
  45.        CURLOPT_HTTPHEADER => array('Content-Type: application/xml'), 
  46.       CURLOPT_POST => 1, 
  47.       CURLOPT_COOKIEFILE => COOKIEJAR, 
  48.       CURLOPT_POSTFIELDS => $postStr3
  49.       CURLOPT_REFERER => 'http://eg1a120.mail.163.com/a/f/js3/0811050934/index_v12.htm'
  50.     ); 
  51.     $mailsxml = curl_quest($options3,true); 
  52.      
  53.     //输出获得的通讯录xml 
  54.     header("Content-Type: application/xml"); 
  55.     echo $mailsxml
  56.      
  57.     function curl_quest($ops,$return = false){ 
  58.         $ch = curl_init();  
  59.        curl_setopt_array($ch,$ops); 
  60.         ob_start( ); 
  61.         curl_exec($ch); 
  62.         if($return){ 
  63.             $content=ob_get_contents(); 
  64.         } 
  65.         curl_close($ch); 
  66.         ob_end_clean(); 
  67.         if($return){ 
  68.             return $content
  69.         } 
  70.     } 
  71.  
  72. ?> 
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门