国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

php 模擬用戶自動在qq空間發表文章

2024-05-04 21:48:46
字體:
來源:轉載
供稿:網友

我們這里是一個簡單的利用php來php 模擬登錄后再到QQ空間發送文章的一個簡單的程序,有需要的朋友可以參考,或改進可以給我意見,代碼如下:

  1. <?php 
  2. //模擬get post請求函數 
  3. /* 
  4. 函數說明: 
  5. 功能:請求方式可以get,post,可以發送的cookie,保存的cookiefile文件 
  6. 參數:$url-----請求url    $referer---來源url    $postdata----------用于post請求的數據,''為get請求 
  7. $cookie---------發送的cookie     $cookiefile-----保存的cookiefile文件 
  8. 返回值:返回獲取的源碼 
  9. */ 
  10. function request($url,$referer='',$postdata='',$cookie='',$cookiefile=''){ 
  11. //header設置 
  12. $header=''
  13. $header.="Content-Type: application/x-www-form-urlencodedrn";//內容請求類型 
  14. $header.="User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0)rn";//瀏覽器字段 
  15. $header.="Referer:".$referer."rn";//設置來源地址 
  16. $header .= "Cookie:".$cookie ; //設置cookie,默認空 
  17. //請求方法get post,通過$postdata空---get,非空----post 
  18. if($postdata=='')$method='GET'
  19. else $method='POST'
  20. //定義用于創建流的數組 
  21. $opts=array(); 
  22. $opts['http']=array('method'=>$method,'header'=>$header,'content'=>$postdata); 
  23. //生成流 
  24. $context=stream_context_create($opts); 
  25. //發送請求,獲取源碼 
  26. $yuanma=file_get_contents($url,false,$context); 
  27. //是否需要保存cookie到文件,$cookiefile不空時 
  28. if($cookiefile!=''){ 
  29. echo '需要保存cookie<br>'
  30. //判斷保存文件存在,不存在創建 
  31. if(!file_exists($cookiefile)){ 
  32. file_put_contents($cookiefile,''); 
  33. //獲取cookie,保存起來 
  34. $response=implode("rn",$http_response_header); 
  35. //用正則匹配cookie 
  36. $zengze="/Set-Cookie:(.*?)rn/"
  37. preg_match_all($zengze,$response,$cookie_arr); 
  38. //存在匹配,保存 
  39. if(!emptyempty($cookie_arr[1])){ 
  40. $cookiestr=implode(';',$cookie_arr[1]); 
  41. file_put_contents($cookiefile,$cookiestr); 
  42. echo '成功保存cookie<br>'
  43. else echo '沒有匹配到cookie<br>'
  44. }//end if($cookiefile!='') 
  45. //返回源碼 
  46. return $yuanma
  47. }//end function request($url,$referer,$postdata,$cookie,$cookiefile)  
  48. //獲得當前的腳本網址  
  49. function GetCurUrl()  
  50. {  
  51. if(!emptyempty($_SERVER["REQUEST_URI"]))  
  52. {  
  53. $scriptName = $_SERVER["REQUEST_URI"];  
  54. $nowurl = $scriptName;  
  55. }  
  56. else  
  57. {  
  58. $scriptName = $_SERVER["PHP_SELF"];  
  59. if(emptyempty($_SERVER["QUERY_STRING"]))  
  60. {  
  61. $nowurl = $scriptName;  
  62. }  
  63. else  
  64. {  
  65. $nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];  
  66. }  
  67. }  
  68. return $nowurl;  
  69.  
  70.  
  71. //獲得當前文件名 
  72. $nowurl=GetCurUrl(); 
  73. //echo $nowurl; 
  74.  
  75. //表單輸出,沒有提交時 
  76. if(!isset($_POST['qq'])){ 
  77. echo '<form method="post" action="'.$nowurl.'"> 
  78. qq號碼:<input type="text" name="qq"><br> 
  79. g_tk:<input type="text" name="g_tk"><br> 
  80. 標題:<input type="text" name="title"><br> 
  81. 內容:<input type="text" name="content"><br> 
  82. <input type="submit" value="發表文章"
  83. </form>'; 
  84. die(); 
  85.  
  86.  
  87. /* 
  88. 提交參數說明: 
  89. $_POST['qq']---用戶QQ 
  90. $_POST['g_tk']--這個參數很關鍵,獲得這個參數,需要抓下發表時提交的post地址后面調用的g_tk=1276354485, 
  91. 路POST http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk=1276354485里的g_tk=1276354485 
  92. $_POST['title']---文章標題,不得空 
  93. $_POST['content']---文章內容,不得空 
  94. */ 
  95.  
  96. header('Content-Type:text/html;charset=gb2312'); 
  97. set_time_limit(0); 
  98. //ob_end_clean(); 
  99. //ob_start(); 
  100.  
  101. //獲取cookie文件,不存在創建,并退出程序 
  102. $cookiefile=dirname(__FILE__).'/qq_cookie.txt'
  103. if(!file_exists($cookiefile)){ 
  104. echo 'qq_cookie.txt不存在,自動創建,請填寫抓包的cookie<br>'
  105. file_put_contents($cookiefile,''); 
  106. die('程序退出'); 
  107. //存在,讀取cookie 
  108. else
  109. $cookie=file_get_contents($cookiefile);//登錄cookie 
  110. //$cookie=urlencode($cookie); 
  111. //echo 'cookie:'.$cookie.'<br>'; 
  112.  
  113. //構成發表頁,post數據等的重要信息 
  114. //qq號碼 
  115. if(emptyempty($_POST['qq'])||preg_match('/[^0-9]/is',$_POST['qq']))die('qq號碼有誤,必須數字'); 
  116. else $qq=$_POST['qq'];//qq號 
  117. if(emptyempty($_POST['g_tk'])||preg_match('/[^0-9]/is',$_POST['g_tk']))die('post重要參數g_tk不合法,必須數字,請使用抓包的值'); 
  118. $g_tk=$_POST['g_tk']; 
  119.  
  120. $title=emptyempty($_POST['title'])?die('標題不得空'):$_POST['title'];//文章標題 
  121. $content=emptyempty($_POST['content'])?die('內容不得空'):$_POST['content'];//內容 
  122.  
  123. $category='個人日記';//分類 
  124. $fabiao='http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk='.$g_tk;//發表處理頁 
  125. $referer='http://ctc.qzs.qq.com/qzone/v5/toolpages/fp_gbk.html';//來源頁 
  126. $r1='http://user.qzone.qq.com/'.$qq.'/infocenter';//列表訪問來源頁 
  127. $postdata='uin='.$qq.'&category='.urlencode($category).'&title='.urlencode($title).'&content='.urlencode($content).'&html='.urlencode('<div class="blog_details_20110920">'.$content.'</div>').'&tweetflag=0&cb_autograph=1&topflag=0&needfeed=0&g_tk='.$g_tk.'&_fp_refer=http%3A%2F%2Fctc.qzs.qq.com%2Fqzone%2Fnewblog%2Fv5%2Feditor.html%3Fsource%3D1%7Chttp%3A%2F%2Fctc.qzs.qq.com%2Fqzone%2Fnewblog%2Fv5%2Feditor.html%3Fsource%3D1%3Chttp%3A%2F%2Fuser.qzone.qq.com%2F'.$qq.'%2Fmain';//post數據 
  128. //$postdata=urlencode($postdata); 
  129. //echo $postdata; 
  130. //發送請求,獲取源碼 
  131. $yuanma=request($fabiao,$r1,$postdata,$cookie,''); 
  132. if(strpos($yuanma,'發表成功'))echo $title.'  發表成功<br>'
  133. else echo '發表失敗:右鍵查看源碼,可以看到具體錯誤'.$yuanma
  134. //開源代碼Vevb.com 
  135. ?> 

php腳本:注意需要保存命名隨意已經自動識別,我是命名為qq_fabiao.php,然后設置提交地址,cookie文件qq_cookie.txt需要填寫抓包獲取的空間登錄cookie,以通過登錄驗證,qq_cookie.txt與php文件同目錄.

提交參數說明:

$_POST['qq']---用戶QQ

$_POST['g_tk']--這個參數很關鍵,獲得這個參數,需要抓下發表時提交的post地址后面調用的g_tk=1276354485,POST http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk=1276354485里的g_tk=1276354485

$_POST['title']---文章標題,不得空

$_POST['content']---文章內容,不得空

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 全州县| 习水县| 黄浦区| 建瓯市| 炎陵县| 定边县| 和政县| 东阿县| 任丘市| 井陉县| 句容市| 蓝山县| 苗栗市| 星座| 博客| 增城市| 东海县| 红桥区| 云南省| 章丘市| 庆安县| 平南县| 临潭县| 丰台区| 宜黄县| 新津县| 呼和浩特市| 淳安县| 聊城市| 平顶山市| 甘谷县| 皋兰县| 丹棱县| 广元市| 梁山县| 怀安县| 阜宁县| 峡江县| 万宁市| 洞头县| 安泽县|