PHP中使用CURL获取页面title例子_PHP
풀어 주다: 2016-05-31 13:18:14
通过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;
}
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
-
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