用PHP模拟登陆(引自http://www.tianjiaonet.com)

2005-01-23
用PHP模拟登陆
经常会有人问模拟登陆的问题,其实原理很简单,只要把SessionID保存下来就可以了,今天花了一个小时的时间写了一个函数,供大家参考,网站返回的头信息,具体网站具体分析。
源代码:
<?php
/* 
* 得到网页内容 
* 参数:$host [in] string
*      主机名称(例如: www.imsorry.com.cn)
* 参数:$method [in] string
*      提交方法: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($ip80);
    if (!$fpreturn;
    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),04== "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),04== "POST")
    {
        fputs($fp$str."/r/n");
    }
    while(!feof($fp))
    {
        $response .= fgets($fp1024);
    }
    $hlen = strpos($response,"/r/n/r/n"); // LINUX下是 "/n/n"
    $header = substr($response0$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>";
    // 不可以访问user.php,因为不带sessid参数
    $response = GetWebContent("localhost","GET /user.php HTTP/1.0"'''');
    echo $response['location']."<br>"// 结果:error.php?errcode=2

    // 可以访问user.php
    $response = GetWebContent("localhost","GET /user.php HTTP/1.0"''$response['sessid']);
    echo $response['location']."<br>"// 结果:user.php
}
?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值