php模拟登陆的代码,用PHP模拟登陆_php

/*

* 得到网页内容

* 参数:$host [in] string

*      主机名称(例如: www.imsorry.com.cn)

* 参数:$method [in] string

http://www.gaodaima.com/48028.html用PHP模拟登陆_php

*      提交方法:POST, GET, HEAD ... 并加上相应的参数( 具体语法参见 RFC1945,RFC2068 )

* 参数:$str [in] string

*      提交的内容

* 参数:$sessid [in] string

*      PHP的SESSIONID

*

* @返回 网页内容 string

*/

function GetwebContent($host, $method, $str, $sessid = '')

{

$ip = gethostbyname($host);

$fp = fsockopen($ip, 80);

if (!$fp) return;

fputs($fp, "$method/r/n");

fputs($fp, "Host: $host/r/n");

if (!empty($sessid))

{

fputs($fp, "Cookie: PHPSESSID=$sessid; path=/;/r/n");

}

if ( substr(trim($method),0, 4) == "POST")

{

fputs($fp, "Content-Length: ". strlen($str) . "/r/n"); //  别忘了指定长度

}

fputs($fp, "Content-Type: application/x-www-form-urlencoded/r/n/r/n");

if ( substr(trim($method),0, 4) == "POST")

{

fputs($fp, $str."/r/n");

}

while(!feof($fp))

{

$response .= fgets($fp, 1024);

}

$hlen = strpos($response,"/r/n/r/n"); // linux下是 "/n/n"

$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']."
";

echo $response['sessid']."
";

if ( preg_match('/error/.php/i',$response['location']))

{

echo "登陆失败
";

} else {

echo "登陆成功
";

// 不可以访问user.php,因为不带sessid参数

$response = GetWebContent("localhost","GET /user.php HTTP/1.0", '', '');

echo $response['location']."
"; // 结果:error.php?errcode=2

// 可以访问user.php

$response = GetWebContent("localhost","GET /user.php HTTP/1.0", '', $response['sessid']);

echo $response['location']."
"; // 结果:user.php

}

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值