温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

php curl爬取网站数据的方法

发布时间:2021-02-22 16:01:09 来源:亿速云 阅读:168 作者:清风 栏目:编程语言

这篇“php curl爬取网站数据的方法”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“php curl爬取网站数据的方法”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起来看看具体内容吧。

php有什么用

php是一个嵌套的缩写名称,指的是英文超级文本预处理语言(php:Hypertext Preprocessor)的缩写,它的语法混合了C、Java、Perl以及php自创新的语法,主要用来做网站开发,许多小型网站都用php开发,因为php是开源的,从而使得php经久不衰。

php curl 爬取网站数据

今天帮一朋友爬取一网站数据,涉及到PHP CURL模块的使用。总结一下整个过程思路:

1.保证curl扩展模块可用,如不可用,请在php.ini配置中打开php_curl.dll扩展;

2.初始化curl对象,并配置curl的参数:

$ch = curl_init();
// 有部分web服务验证了HTTP头,该参数表示使用当前浏览器HTTP;
curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']); 
curl_setopt($ch, CURLOPT_HEADER, 0);  // 不输出header头
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_TIMEOUT, 100);  // 超时设置

3.保存或传替cookie,因为web服务可能检查了session或cookie,在这种情况下我们需要发送cookie信息:

// 设置cookie,格式为cookiename1 = cookievalue1; cookiename2 = cookievalue2; …… 
curl_setopt($ch, CURLOPT_COOKIE, $cookie);

或者把该web的cookie保存成文件,自动传递

curl_setopt($ch, CURLOPT_COOKIEJAR, $cookiepath);   // 保存cookie文件
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookiepath);   // 从文件传递cookie

4.伪造引用信息,因为web服务可能检查了引用信息,非对应域名的不能通过验证,那么我们可以伪造referer引用信息:

curl_setopt($ch, CURLOPT_REFERER, $referer);

5.如果POST数据,那么应设置提交的数据

curl_setopt($ch, CURLOPT_POST, 1);
// 数据的格式为var1=value1&var2=value2……
curl_setopt($ch, CURLOPT_POSTFIELDS, $data);

6.获取结果,关闭curl:

$rs = curl_exec($ch);
curl_close($ch);

7.处理数据,数据爬下来后,我们使用正则表达式进行匹配处理,获取需要的数据:

preg_match_all($pattern, $rs, $matchs);

这里写了一个通过的函数,大家可以参考:

function curl($url, $data = null, $cookie = null, $referer = null) {
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_USERAGENT, $_SERVER['HTTP_USER_AGENT']);
    curl_setopt($ch, CURLOPT_HEADER, 0);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
    curl_setopt($ch, CURLOPT_TIMEOUT, 100);

    if ($data != null) {
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, 
                (is_array($data) ? paramArray($data) : $data));
    }

    if ($cookie != null) {
        if (strpos($cookie, '=')) {  // cookie字串
            curl_setopt($ch, CURLOPT_COOKIE, $cookie);
        } else {  // cookie文件
            // 保存cookie文件
            curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie); 
            // 从文件传递cookie
            curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie);
        }
    }

    if ($referer === null) {
        curl_setopt($ch, CURLOPT_AUTOREFERER, 1);
    } else {
        curl_setopt($ch, CURLOPT_REFERER, $referer);
    }

    $content = curl_exec($ch);
    curl_close($ch);

    return $content;
}

function paramArray($data) {
    $param = '';
    foreach ($data as $k => $v) {
        $param .= "&$k=" . urlencode($v);
    }
    return substr($param, 1);
}

感谢你的阅读,希望你对“php curl爬取网站数据的方法”这一关键问题有了一定的理解,具体使用情况还需要大家自己动手实验使用过才能领会,快去试试吧,如果想阅读更多相关知识点的文章,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI