|
本文分享几段php代码,分别用于获取百度快照时间、百度收录情况、百度热词。有需要的朋友作个参考。
用php获取百度快照、百度收录、百度热词,供大家参考。 1,获取百度收录
/*
* 百度收录
* $s 为要查询的网站域名
* by bbs.it-home.org
*/
function baidu($s){
$baidu="http://www.baidu.com/s?wd=site%3A".$s;
$site=file_get_contents($baidu);
//$site=iconv("gb2312", "UTF-8", $site);
ereg("找到相关网页(.*)篇,", $site,$count);
$count=str_replace("找到相关网页","",$count);
$count=str_replace("篇,","",$count);
$count=str_replace("约","",$count);
$count=str_replace(",","",$count);
return $count[0];
}
echo baidu(bbs.it-home.org); //获取好主题在百度中的收录数量
?>
2,获取百度的热词
<?php /**
* @return array 返回百度的热词数据(数组返回)
* @by bbs.it-home.org
*/
function getBaiduHotKeyWord()
{
$templateRss = file_get_contents('http://top.baidu.com/rss_xml.php?p=top10');
If (preg_match('/<table>(.*) |
/is', $templateRss, $_description)) { $templateRss = $_description [0]; $templateRss = str_replace("&", "&", $templateRss); } $templateRss = "" . $templateRss; $xml = simplexml_load_String($templateRss); foreach ($xml->tbody->tr as $temp) { if (!empty ($temp->td->a)) { $keyArray [] = trim(($temp->td->a)); } } return $keyArray; } print_r(getBaiduHotKeyWord()); ?>
3,百度收录和百度快照时间
<?php $domain = “http://bbs.it-home.org/article/10964.html/ *欲查询的域名*/
$site_url = ‘http://www.baidu.com/s?wd=site%3A’;
$all = $site_url.$domain; /*域名所有收录的网址*/
$today = $all.’&lm=1′; /*域名今日收录的网址*/
$utf_pattern = “/找到相关结果数(.*)个/”;
$kz_pattern = “/<span class=”g”>(.*)/”; /*用以匹配快照日期的字符串*/
$times = “/d{4}-d{1,2}-d{1,2}/”; /*匹配快照日期的正则表达式,如:2013-8-4*/
$s0 = @file_get_contents($all); /*将site:bbs.it-home.org的网页置入$s0字符串中*/
$s1 = @file_get_contents($today);
preg_match($utf_pattern,$s0,$all_num); /*匹配”找到相关结果数*个”*/
preg_match($utf_pattern,$s1,$today_num);
preg_match($kz_pattern,$s0,$temp);
preg_match($times,$temp[0],$screenshot);
if($all_num[1] == “”)
$all_num[1] = 0;
if($today_num[1] == “”)
$today_num[1] = 0;
if($screenshot[0] == “”)
$screenshot[0] = “暂无快照”;
?>
<head>
<title>Test</title>
</head><body>
<table>
<tr>
<td>日期</td><td>百度收录</td><td>百度今日收录</td><td>百度快照日期</td>
</tr>
<tr>
<td><?php echo date(‘m月d日G时’);?> </td><td><?php echo $all_num[1]; ?></td><td><?php echo $today_num[1]; ?></td>
<td><?php echo $screenshot[0]; ?></td>
</tr>
</table>
<p>百度收录:” target=”_blank”><?php echo $all_num[1]; ?></p>
<p>百度今日收录:” target=”_blank”><?php echo $today_num[1]; ?>
</p>
<p>百度快照日期:”><?php echo $screenshot[0]; ?></p><div class="aritcle_card flexRow">
<div class="artcardd flexRow">
<a class="aritcle_card_img" href="/xiazai/code/10761" title="通达CMS蓝色中英双语企业网站1.4.2"><img
src="https://img.php.cn/upload/webcode/000/000/010/176362920210614.jpg" alt="通达CMS蓝色中英双语企业网站1.4.2" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a>
<div class="aritcle_card_info flexColumn">
<a href="/xiazai/code/10761" title="通达CMS蓝色中英双语企业网站1.4.2">通达CMS蓝色中英双语企业网站1.4.2</a>
<p>通达CMS是采用PHP+MYSQL进行开发的。支持伪静态设置,可生成google和百度地图,支持自定义url、关键字和描述,利于收录...后台简单明了,代码简洁,采用DIV+CSS 利于SEO,企业建站系统是一套专门用于中小企业网站建设的网站管理系统。</p>
</div>
<a href="/xiazai/code/10761" title="通达CMS蓝色中英双语企业网站1.4.2" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a>
</div>
</div>
</body>
说明: 以上代码,仅供学习研究之用。 如果服务器不支持file_get_contents函数,则可以考虑换用curl操作,它更接近于真实用户访问。










