PHP中使用CURL获取页面title例子_PHP
Freigeben: 2016-05-31 13:18:14
Original
754 Leute haben es durchsucht
通过PHP获取页面title内容的实战演示:
范例代码:
代码如下:
/*
功能: 取得 URL 页面上的
内容
参数:$_POST['url']
*/
// 设置最长执行的秒数
ini_set ("expect.timeout", 30);
set_time_limit(30);
// 检查 URL
if(!isset($_POST['url']) || $_POST['url'] == ''){
echo "URL 错误";
exit;
}
/* 取得 URL 页面数据 */
// 初始化 CURL
$ch = curl_init();
// 设置 URL
curl_setopt($ch, CURLOPT_URL, $_POST['url']);
// 让 curl_exec() 获取的信息以数据流的形式返回,而不是直接输出。
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
// 在发起连接前等待的时间,如果设置为0,则不等待
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, 0);
// 设置 CURL 最长执行的秒数
curl_setopt ($ch, CURLOPT_TIMEOUT, 30);
// 尝试取得文件内容
$store = curl_exec ($ch);
// 检查文件是否正确取得
if (curl_errno($ch)){
echo "无法取得 URL 数据";
//echo curl_error($ch);/*显示错误信息*/
exit;
}
// 关闭 CURL
curl_close($ch);
// 解析 HTML 的 区段
preg_match("/(.*)/smUi",$store, $htmlHeaders);
if(!count($htmlHeaders)){
echo "无法解析数据中的 区段";
exit;
}
// 取得 中 meta 设置的编码格式
if(preg_match("/]*http-equiv[^>]*charset=(.*)(\"|')/Ui",$htmlHeaders[1], $results)){
$charset = $results[1];
}else{
$charset = "None";
}
// 取得 中的文字
if(preg_match("/(.*)/Ui",$htmlHeaders[1], $htmlTitles)){
if(!count($htmlTitles)){
echo "无法解析 的内容";
exit;
}
// 将 的文字编码格式转成 UTF-8
if($charset == "None"){
$title=$htmlTitles[1];
}else{
$title=iconv($charset, "UTF-8", $htmlTitles[1]);
}
echo $title;
}
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31