2
3
4
5
6
7
8
9
10
指定返回json格式,我们只需要添加头信息即可:
$header = array(
'Accept: application/json, text/javascript, */*q=0.01'
)
curl_setopt($ch, CURLOPT_HTTPHEADER, $header)
指定返回json格式,我们只需要添加头信息即可:$header = array(
'Accept: application/json, text/javascript, */* q=0.01'
)
curl_setopt($ch, CURLOPT_HTTPHEADER, $header)
请参考我的博客《PHP cURL实现模拟登录与采集使用方法详解》
http://www.zjmainstay.cn/php-curl
里面的“十一、发送与获取json数据”专门讲解json相关内容。
本文承接上面两篇,本篇中的示例要调用到前两篇中的函数,做一个简单的URL采集。一般php采集网络数据会用file_get_contents、file和cURL。不过据说cURL会比file_get_contents、file更快更专业,更适合采集。今天就试试用cURL来获取网页上的所有链接。示例如下:<?php
/*
* 使用curl 采集hao123.com下的所有链接。
*/
include_once('function.php')
$ch = curl_init()
curl_setopt($ch, CURLOPT_URL, 'http://www.hao123.com/')
// 只需返回HTTP header
curl_setopt($ch, CURLOPT_HEADER, 1)
// 页面内容我们并不需要
// curl_setopt($ch, CURLOPT_NOBODY, 1)
// 返回结果,而不是输出它
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1)
$html = curl_exec($ch)
$info = curl_getinfo($ch)
if ($html === false) {
echo "cURL Error: " . curl_error($ch)
}
curl_close($ch)
$linkarr = _striplinks($html)
// 主机部分,补全用
$host = 'http://www.hao123.com/'
if (is_array($linkarr)) {
foreach ($linkarr as $k =>$v) {
$linkresult[$k] = _expandlinks($v, $host)
}
}
printf("<p>此页面的所有链接为:</p><pre>%s</pre>n", var_export($linkresult , true))
?>
function.php内容如下(即为上两篇中两个函数的合集):
<?php
function _striplinks($document) {
preg_match_all("'<s*as.*?hrefs*=s*(["'])?(?(1) (.*?)\1 | ([^s>]+))'isx", $document, $links)
// catenate the non-empty matches from the conditional subpattern
while (list($key, $val) = each($links[2])) {
if (!empty($val))
$match[] = $val
} while (list($key, $val) = each($links[3])) {
if (!empty($val))
$match[] = $val
}
// return the links
return $match
}
/*===================================================================*
Function: _expandlinks
Purpose: expand each link into a fully qualified URL
Input: $links the links to qualify
$URI the full URI to get the base from
Output: $expandedLinks the expanded links
*===================================================================*/
function _expandlinks($links,$URI)
{
$URI_PARTS = parse_url($URI)
$host = $URI_PARTS["host"]
preg_match("/^[^?]+/",$URI,$match)
$match = preg_replace("|/[^/.]+.[^/.]+$|","",$match[0])
$match = preg_replace("|/$|","",$match)
$match_part = parse_url($match)
$match_root =
$match_part["scheme"]."://".$match_part["host"]
$search = array( "|^http://".preg_quote($host)."|i",
"|^(/)|i",
"|^(?!http://)(?!mailto:)|i",
"|/./|",
"|/[^/]+/../|"
)
$replace = array( "",
$match_root."/",
$match."/",
"/",
"/"
)
$expandedLinks = preg_replace($search,$replace,$links)
return $expandedLinks
}
?>