经常会有人问模拟登陆的问题,其实原理很简单,只要把SessionID保存下来就可以了,今天花了一个小时的时间写了一个函数,供大家参考,网站返回的头信息,具体网站具体分析,源代码:
- <?php
-
-
-
-
-
-
-
-
-
-
-
-
-
- function GetWebContent($host, $method, $str, $sessid = '')
- {
- $ip = gethostbyname($host);
- $fp = fsockopen($ip, 80);
- if (!$fp) return;
- fputs($fp, "$methodrn");
- fputs($fp, "Host: $hostrn");
- if (!emptyempty($sessid))
- {
- fputs($fp, "Cookie: PHPSESSID=$sessid; path=/;rn");
- }
- if ( substr(trim($method),0, 4) == "POST")
- {
- fputs($fp, "Content-Length: ". strlen($str) . "rn");
- }
- fputs($fp, "Content-Type: application/x-www-form-urlencodedrnrn");
- if ( substr(trim($method),0, 4) == "POST")
- {
- fputs($fp, $str."rn");
- }
- while(!feof($fp))
- {
- $response .= fgets($fp, 1024);
- }
- $hlen = strpos($response," ");
- $header = substr($response, 0, $hlen);
- $entity = substr($response, $hlen 4);
- if ( preg_match('/PHPSESSID=([0-9a-z] );/i', $header, $matches))
- {
- $a['sessid'] = $matches[1];
- }
- if ( preg_match('/Location: ([0-9a-z_?=&#.] )/i', $header, $matches))
- {
- $a['location'] = $matches[1];
- }
- $a['content'] = $entity;
- fclose($fp);
- return $a;
- }
-
-
- $str = ("username=test&password=test");
- $response = GetWebContent("localhost","POST /login.php HTTP/1.0", $str);
- echo $response['location'].$response['content']."<br>";
- echo $response['sessid']."<br>";
- if ( preg_match('/error.php/i',$response['location']))
- {
- echo "登陆失败<br>";
- } else {
- echo "登陆成功<br>";
-
- $response = GetWebContent("localhost","GET /user.php HTTP/1.0", '', '');
- echo $response['location']."<br>";
-
-
- $response = GetWebContent("localhost","GET /user.php HTTP/1.0", '', $response['sessid']);
- echo $response['location']."<br>";
- }
- ?>