PHP输入网址获取网站标题,php根据网址获取网页标题和描述

namespace Xuyaoxiang;

class Snoopy {

private $pattern_array=array(

'title'=>'/

(\s*.*)/i',

'description'=>'//',

'charset'=>'/charset=\"?([\w-]+)\"?/i',

);

public $url;

public $target_code="utf-8"; //目标编码

public $user_agent='Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/49.0.2623.110 Safari/537.36'; //模拟浏览器头部数据

function __construct($url)

{

$this->url=$url;

}

public function set_pattern($key,$val)

{

if(isset($this->pattern_array[$key])){return false;}

$this->pattern_array[$key]=$val;

} //只能够添加规则,不能更改原有的规则

function get_pege_content($pattern_key)

{

if($pattern_key=='')

{

return false;

}

$curl=curl_init();

// 设置你需要抓取的URL

curl_setopt($curl, CURLOPT_URL, $this->url);

// 设置header

curl_setopt($curl, CURLOPT_HEADER, 0);

// 设置cURL 参数,要求结果保存到字符串中还是输出到屏幕上。

curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);

curl_setopt($curl, CURLOPT_USERAGENT, $this->user_agent);

// 运行cURL,请求网页

$data = curl_exec($curl);

if($data==false){return false;}

preg_match($this->pattern_array['charset'],$data,$reg_charset); //获取网页编码

$page_charset=strtolower($reg_charset[1]);

$charset==$this->target_code || $data=mb_convert_encoding($data,$this->target_code,$page_charset); //如果不符合你设置的编码,进行转码

preg_match($this->pattern_array[$pattern_key],$data,$content);

// 关闭URL请求

curl_close($curl);

return  trim($content[1]);

}

}

$snoopy=new snoopy("http://www.qq.com");

$title=$snoopy->get_pege_content('title');

print_r($title);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值