我们这里是一个简单的利用php来模拟登录后再到QQ空间发送文章的一个简单的程序,有需要的朋友可以参考,或改进可以给我意见,代码如下:

  1. <?php
  2. //模拟get post请求函数 http://www.lai18.com
  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. }
  34. //获取cookie,保存起来
  35. $response=implode("rn",$http_response_header);
  36. //用正则匹配cookie
  37. $zengze="/Set-Cookie:(.*?)rn/";
  38. preg_match_all($zengze,$response,$cookie_arr);
  39. //存在匹配,保存
  40. if(!emptyempty($cookie_arr[1])){
  41. $cookiestr=implode(';',$cookie_arr[1]);
  42. file_put_contents($cookiefile,$cookiestr);
  43. echo '成功保存cookie<br>';
  44. }
  45. else echo '没有匹配到cookie<br>';
  46. }//end if($cookiefile!='')
  47. //返回源码
  48. return $yuanma;
  49. }//end function request($url,$referer,$postdata,$cookie,$cookiefile)
  50. //获得当前的脚本网址
  51. function GetCurUrl()
  52. {
  53. if(!emptyempty($_SERVER["REQUEST_URI"]))
  54. {
  55. $scriptName = $_SERVER["REQUEST_URI"];
  56. $nowurl = $scriptName;
  57. }
  58. else
  59. {
  60. $scriptName = $_SERVER["PHP_SELF"];
  61. if(emptyempty($_SERVER["QUERY_STRING"]))
  62. {
  63. $nowurl = $scriptName;
  64. }
  65. else
  66. {
  67. $nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];
  68. }
  69. }
  70. return $nowurl;
  71. }
  72. //获得当前文件名
  73. $nowurl=GetCurUrl();
  74. //echo $nowurl;
  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. $_POST['qq']---用户QQ
  89. $_POST['g_tk']--这个参数很关键,获得这个参数,需要抓下发表时提交的post地址后面调用的g_tk=123456789,
  90. 路POST <a href="http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk=123456789里的g_tk=123456789" target="_blank">http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk=123456789里的g_tk=123456789</a>
  91. $_POST['title']---文章标题,不得空
  92. $_POST['content']---文章内容,不得空
  93. */
  94. header('Content-Type:text/html;charset=gb2312');
  95. set_time_limit(0);
  96. //ob_end_clean();
  97. //ob_start();
  98. //获取cookie文件,不存在创建,并退出程序
  99. $cookiefile=dirname(__FILE__).'\qq_cookie.txt';
  100. if(!file_exists($cookiefile)){
  101. echo 'qq_cookie.txt不存在,自动创建,请填写抓包的cookie<br>';
  102. file_put_contents($cookiefile,'');
  103. die('程序退出');
  104. }
  105. //存在,读取cookie
  106. else{
  107. $cookie=file_get_contents($cookiefile);//登录cookie
  108. //$cookie=urlencode($cookie);
  109. }
  110. //echo 'cookie:'.$cookie.'<br>';
  111. //构成发表页,post数据等的重要信息
  112. //qq号码
  113. if(emptyempty($_POST['qq'])||preg_match('/[^0-9]/is',$_POST['qq']))die('qq号码有误,必须数字');
  114. else $qq=$_POST['qq'];//qq号
  115. if(emptyempty($_POST['g_tk'])||preg_match('/[^0-9]/is',$_POST['g_tk']))die('post重要参数g_tk不合法,必须数字,请使用抓包的值');
  116. $g_tk=$_POST['g_tk'];
  117. $title=emptyempty($_POST['title'])?die('标题不得空'):$_POST['title'];//文章标题
  118. $content=emptyempty($_POST['content'])?die('内容不得空'):$_POST['content'];//内容
  119. $category='个人日记';//分类
  120. $fabiao='http://b1.qzone.qq.com/cgi-bin/blognew/blog_add?g_tk='.$g_tk;//发表处理页
  121. $referer='http://ctc.qzs.qq.com/qzone/v5/toolpages/fp_gbk.html';//来源页
  122. $r1='http://user.qzone.qq.com/'.$qq.'/infocenter';//列表访问来源页
  123. $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数据
  124. //$postdata=urlencode($postdata);
  125. //echo $postdata;
  126. //发送请求,获取源码
  127. $yuanma=request($fabiao,$r1,$postdata,$cookie,'');
  128. if(strpos($yuanma,'发表成功'))echo $title.'  发表成功<br>';
  129. else echo '发表失败:右键查看源码,可以看到具体错误'.$yuanma;
  130. ?>

代码仅供参考,成功率有待大家的验证

最新文章

  1. Organization SYMMETRIC MULTIPROCESSORS
  2. NYOJ题目98成绩转换
  3. Log4net日志GUI配置工具
  4. 在服务器上log4net没写日志
  5. Gradle多渠道打包[umeng]
  6. TCP/IP详解学习笔记(14)-TCP连接的未来和性能(未写完)
  7. 软件测试技术(二)——使用等价类划分的方法进行的UI测试
  8. 编写3个不同版本的程序,令其均能输出ia的元素
  9. 20160427Struts2--入门1
  10. MVC理解
  11. JavaWeb显示器
  12. mosquitto awareness when before it&#39;s being compiling, and you do settings and testing
  13. hive metastore &amp;&amp; hiveserver2 . jvm 配置调整优化
  14. 【转】Sqlserver将数据从一个表插入到另一个表
  15. centos 7 一键安装gitlab
  16. what&#39; the python之面向对象(进阶)
  17. BitArray源码解析
  18. hibernate 注释 唯一键约束 uniqueConstraints
  19. MyEclipse 智能提示设置
  20. 【bzoj1878】[SDOI2009]HH的项链

热门文章

  1. getchar(),gets(),scanf()的差异比较
  2. ASP.NET中利用Split实现对Checkbox的字符串分离放到DataTable里面
  3. int main(int argc,char* argv[])参数详解
  4. 【Go】http server 性能测试
  5. ios自定义选择器ActionSheetPicker改进版
  6. ThinkPHP/Common/extend.php
  7. Java 8 VM GC Tunning Guide Charter 6
  8. 巨大bug
  9. 一个SQL Server 2008 R2 死锁的问题解决
  10. ora-28002 the password will expire解决办法