美文网首页
登陆网站获取信息的爬虫的php实现(慕课网为例)

登陆网站获取信息的爬虫的php实现(慕课网为例)

作者: Tangbh | 来源:发表于2017-03-13 19:22 被阅读282次

    步骤及原理:
    1、在信息类中新建一个变量,用来保存cookie。每次请求时判断cookie是否为空。

    2、如果cookie为空的话,使用curl,设置好请求url,referer,useragent等参数,向登陆页面进行请求,获取到登陆页面的cookie。

    2、获取到登陆页面的cookie之后,设置好curl的各项参数,一般最好附带referer,表示发起请求的页面。将post区域附带好用户名密码及其他相关必要参数,向登陆地址请求(一般post的数据不止是用户名密码,还附带各种状态),然后执行curl。

    3、服务器接收到登陆请求后,一般会设置session,返回的http的头中,会包含在客户端设置cookie的信息,用于保持登陆状态。

    4、http的返回头中有一行set-cookie,可以用正则表达式将其抽离出来,这个就是我们要的登陆状态的cookie了。(为了方便匹配,可以先将http头分离出来,可以用curl_getinfo()函数获取到头的长度,方便截取。)

    5、可以用curl_getinfo()函数来获取到状态码,来判断登陆状态。

    6、下一次请求时携带获取到的cookie,即可完成登陆,获取到登陆界面的信息。

    以下是登陆慕课网的示例:

    $data='username=xxxxxxx@126.com&password=xxxxxxx&remember=1';
    $curlobj = curl_init();         // 初始化
    curl_setopt($curlobj, CURLOPT_URL, "http://www.imooc.com/user/login");      // 设置访问网页的URL
    curl_setopt($curlobj, CURLOPT_RETURNTRANSFER, true);            // 执行之后不直接打印出来
    
    // Cookie相关设置,这部分设置需要在所有会话开始之前设置
    date_default_timezone_set('PRC'); // 使用Cookie时,必须先设置时区
    curl_setopt($curlobj, CURLOPT_COOKIESESSION, TRUE); 
    curl_setopt($curlobj, CURLOPT_HEADER, 0); 
    // 注释掉这行,因为这个设置必须关闭安全模式 以及关闭open_basedir,对服务器安全不利
    //curl_setopt($curlobj, CURLOPT_FOLLOWLOCATION, 1);  
    
    curl_setopt($curlobj, CURLOPT_POST, 1);  
    curl_setopt($curlobj, CURLOPT_POSTFIELDS, $data);  
    curl_setopt($curlobj, CURLOPT_HTTPHEADER, array("application/x-www-form-urlencoded; charset=utf-8", 
        "Content-length: ".strlen($data)
        ));     //设置http请求头中的信息,以此让服务器认为是浏览器发出的请求
    curl_exec($curlobj);    // 执行
    curl_setopt($curlobj, CURLOPT_URL, "http://www.imooc.com/space/index");
    curl_setopt($curlobj, CURLOPT_POST, 0);  
    curl_setopt($curlobj, CURLOPT_HTTPHEADER, array("Content-type: text/xml"
        )); 
    $output=curl_redir_exec($curlobj);  // 执行
    curl_close($curlobj);           // 关闭cURL
    echo $output;
    
    /**
     * 自定义实现页面链接跳转抓取
     */
    function curl_redir_exec($ch,$debug="") 
    { 
        static $curl_loops = 0; 
        static $curl_max_loops = 20; 
    
        if ($curl_loops++ >= $curl_max_loops) 
        { 
            $curl_loops = 0; 
            return FALSE; 
        } 
        curl_setopt($ch, CURLOPT_HEADER, true); // 开启header才能够抓取到重定向到的新URL
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
        $data = curl_exec($ch); 
        // 分割返回的内容
        $h_len = curl_getinfo($ch, CURLINFO_HEADER_SIZE); 
        $header = substr($data,0,$h_len);
        $data = substr($data,$h_len - 1);
    
        $http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE); 
        if ($http_code == 301 || $http_code == 302) { 
            $matches = array(); 
            preg_match('/Location:(.*?)\n/', $header, $matches); 
            $url = @parse_url(trim(array_pop($matches))); 
            // print_r($url); 
            if (!$url) 
            { 
                //couldn't process the url to redirect to 
                $curl_loops = 0; 
                return $data; 
            } 
            $last_url = parse_url(curl_getinfo($ch, CURLINFO_EFFECTIVE_URL)); 
            if (!isset($url['scheme'])) 
                $url['scheme'] = $last_url['scheme']; 
            if (!isset($url['host'])) 
                $url['host'] = $last_url['host']; 
            if (!isset($url['path'])) 
                $url['path'] = $last_url['path'];
    
            $new_url = $url['scheme'] . '://' . $url['host'] . $url['path'] . (isset($url['query'])?'?'.$url['query']:''); 
            curl_setopt($ch, CURLOPT_URL, $new_url); 
    
            return curl_redir_exec($ch); 
        } else { 
            $curl_loops=0; 
            return $data; 
    }
    

    相关文章

      网友评论

          本文标题:登陆网站获取信息的爬虫的php实现(慕课网为例)

          本文链接:https://www.haomeiwen.com/subject/dzdqnttx.html