天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

curl實現站外采集的方法和技巧

選擇curl的理由

關于curl與file_get_contents,摘抄一段通俗易懂的對比:
file_get_contents其實是一堆內置的文件操作函數的合并版本,比如file_exists,fopen,fread,fclose,專門提供給懶人用的,而且它主要是用來對付本地文件的,但又是因為懶人的原因,同時加入了對網絡文件的支持;
curl是專門用來進行網絡交互的庫,提供了一堆自定義選項,用來應對不同的環境,穩定性自然要大于file_get_contents。

使用方法

1、開啟curl支持

由于php環境安裝后默認是沒有打開curl支持的,需修改php.ini文件,找到;extension=php_curl.dll,把前面的冒號去掉,重啟服務即可;

2、使用curl進行數據抓取

復制代碼 代碼如下:
// 初始化一個 cURL 對象
$curl = curl_init();
// 設置你需要抓取的URL
curl_setopt($curl, CURLOPT_URL, 'http://www.cmx8.cn');
// 設置header
curl_setopt($curl, CURLOPT_HEADER, 1);
// 設置cURL 參數,要求結果保存到字符串中還是輸出到屏幕上。
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
// 運行cURL,請求網頁
$data = curl_exec($curl);
// 關閉URL請求
curl_close($curl);

3、通過正則匹配找到關鍵數據

復制代碼 代碼如下:
//$data是curl_exec返回的的值,即采集的目標內容
preg_match_all("/<li class=/"item/">(.*?)<//li>/",$data, $out, PREG_SET_ORDER);
foreach($out as $key => $value){
    //此處$value是數組,同時記錄找到帶匹配字符的整句和單獨匹配的字符
    echo '匹配到的整句:'.$value[0].'
';
    echo '單獨匹配到的:'.$value[1].'
';
}

技巧

1、超時的相關設置

通過curl_setopt($ch, opt) 可以設置一些超時的設置,主要包括:

CURLOPT_TIMEOUT 設置cURL允許執行的最長秒數。
CURLOPT_TIMEOUT_MS 設置cURL允許執行的最長毫秒數。 (在cURL 7.16.2中被加入。從php 5.2.3起可使用。 )
CURLOPT_CONNECTTIMEOUT 在發起連接前等待的時間,如果設置為0,則無限等待。
CURLOPT_CONNECTTIMEOUT_MS 嘗試連接等待的時間,以毫秒為單位。如果設置為0,則無限等待。 在cURL 7.16.2中被加入。從php 5.2.3開始可用。
CURLOPT_DNS_CACHE_TIMEOUT 設置在內存中保存DNS信息的時間,默認為120秒。

復制代碼 代碼如下:
curl_setopt($ch, CURLOPT_TIMEOUT, 60);   //只需要設置一個秒的數量就可以
curl_setopt($ch, CURLOPT_NOSIGNAL, 1);    //注意,毫秒超時一定要設置這個
curl_setopt($ch, CURLOPT_TIMEOUT_MS, 200);  //超時毫秒,cURL 7.16.2中被加入。從php 5.2.3起可使用

2、通過post提交數據,保留cookie

復制代碼 代碼如下:
//以下摘抄一個例子過來,用于學習借鑒:
//Curl 模擬登錄 discuz 程序,適合DZ7.0

!extension_loaded('curl') && die('The curl extension is not loaded.');   

$discuz_url = 'http://www.lxvoip.com';//論壇地址   
$login_url = $discuz_url .'/logging.php?action=login';//登錄頁地址   
$get_url = $discuz_url .'/my.php?item=threads'; //我的帖子   

$post_fields = array();   
//以下兩項不需要修改   
$post_fields['loginfield'] = 'username';   
$post_fields['loginsubmit'] = 'true';   
//用戶名和密碼,必須填寫   
$post_fields['username'] = 'lxvoip';   
$post_fields['password'] = '88888888';   
//安全提問   
$post_fields['questionid'] = 0;   
$post_fields['answer'] = '';   
//@todo驗證碼   
$post_fields['seccodeverify'] = '';   

//獲取表單FORMHASH   
$ch = curl_init($login_url);   
curl_setopt($ch, CURLOPT_HEADER, 0);   
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);   
$contents = curl_exec($ch);   
curl_close($ch);   
preg_match('/<input/s*type="hidden"/s*name="formhash"/s*value="(.*?)"/s*//>/i', $contents, $matches);   
if(!empty($matches)) {   
    $formhash = $matches[1];   
} else {   
    die('Not found the forumhash.');   
}   

//POST數據,獲取COOKIE   
$cookie_file = dirname(__FILE__) . '/cookie.txt';   
//$cookie_file = tempnam('/tmp');   
$ch = curl_init($login_url);   
curl_setopt($ch, CURLOPT_HEADER, 0);   
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);   
curl_setopt($ch, CURLOPT_POST, 1);   
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_fields);   
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie_file);   
curl_exec($ch);   
curl_close($ch);   

//帶著上面得到的COOKIE獲取需要登錄后才能查看的頁面內容   
$ch = curl_init($get_url);   
curl_setopt($ch, CURLOPT_HEADER, 0);   
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);   
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie_file);   
$contents = curl_exec($ch);   
curl_close($ch);   

var_dump($contents);

php技術curl實現站外采集的方法和技巧,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲AV久久无码精品九九软件 | 亚洲精品久久久久AV无码林星阑 | 在线亚洲精品福利网址导航 | 久久精品中文字幕免费 | 任你躁精品一区二区三区 | 性夜夜春夜夜爽AA片A | 男人把女人桶到爽免费看视频 | 好看AV中文字幕在线观看 | 欧美精品一区二区在线电影 | 兰桂坊人成社区亚洲精品 | 酒色.com| 欧美片内射欧美美美妇 | 最近中文字幕完整版高清 | 亚洲日韩国产成网站在线 | 色哟哟网站入口在线观看视频 | 日本中文字幕巨大的乳专区 | 好满射太多了装不下了视频 | 久久影院午夜理论片无码 | 蜜芽在线影片 | 三级视频黄色 | 久久亚洲精品成人综合 | 欧美性喷潮xxxx | 国产伦精品一区二区三区精品 | 成人毛片一区二区三区 | 草草久久久无码国产专区全集观看 | 女王羞辱丨vk | 亚洲视频在线观看视频 | 99精品国产免费观看视频 | 中文字幕精品在线观看 | 岳打开双腿开始配合日韩视频 | 与邻居换娶妻子2在线观看 瑜伽牲交AV | 国产欧美日韩国产高清 | 国产成人在线视频免费观看 | 99热热在线精品久久 | 亚洲精品综合在线影院 | 日韩欧美一级 | 国产精品亚洲第一区二区三区 | 牛牛免费视频 | 99热这里只有精品视频2 | 四虎免费影院 | 午夜性爽视频男人的天堂在线 |