織夢(mèng)cms實(shí)時(shí)推送sitemap地址給百度
時(shí)間: 2020-09-10 09:21
閱讀: 次
作者:素材無憂網(wǎng)
很久前,織夢(mèng)dedecms自己有一套主動(dòng)ping百度的插件,但是后來好像有幾年用不了了 。
最近百度推出了實(shí)時(shí)推送鏈接地址給百度,這樣肯定比sitemap方便多了.而且也可以確保文章的原創(chuàng)性。
不知道為什么我在網(wǎng)上還沒看到織夢(mèng)有這樣的教程,所以我就根據(jù)百度接口寫了個(gè)教程出來,給各位織夢(mèng)愛好者看看 。
關(guān)于織夢(mèng)的百度實(shí)時(shí)推送我寫了兩種方法,大家可以自行選擇 :
1、
手動(dòng)創(chuàng)建一個(gè)文件,每天訪問這個(gè)文件就可以把當(dāng)天的全部文章推送到百度搜索引擎.
在根目錄下面創(chuàng)建一個(gè)fcz8k.php 訪問后會(huì)返回百度接口結(jié)果
代碼如下
<?php
require_once ("include/common.inc.php");
require_once "include/arc.partview.class.php";
require_once('include/charset.func.php');
$year = date("Y");
$month = date("m");
$day = date("d");
$dayBegin = mktime(0,0,0,$month,$day,$year);//當(dāng)天開始時(shí)間戳
$dayEnd = mktime(23,59,59,$month,$day,$year);//當(dāng)天結(jié)束時(shí)間戳
$query = "SELECT arch.id,types.typedir FROM dede_arctype as types inner join dede_archives as arch on types.id=arch.typeid where pubdate<".$dayEnd." AND pubdate>".$dayBegin.""; //這里dede換成你們自己的表前綴
$urls="";
$dsql->Execute('arch.id,types.typedir',$query);
while($row = $dsql->GetArray('arch.id,types.typedir'))
{
$urls.="http://fcz8k.com".str_replace("{cmspath}","",$row['typedir'])."/".$row[id].".html".",";
//將上邊的http://fcz8k.com換成你的網(wǎng)址
}
$urls=substr($urls,0,-1);
$urls = explode(",",$urls);
$api = 'http://data.zz.baidu.com/urls?site=youwujun.com.cn&token=xxxxx'; // 前邊的site換成自己的site xxx換成自己的密鑰
$ch = curl_init();
$options = array(
CURLOPT_URL => $api,
CURLOPT_POST => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_POSTFIELDS => implode(" ", $urls),
CURLOPT_HTTPHEADER => array('Content-Type: text/plain'),
);
curl_setopt_array($ch, $options);
$result = curl_exec($ch);
echo $result.count($urls);
?>
百度接口返回說明:
推送成功
狀態(tài)碼為200,可能返回以下字段:
字段
是否必選
參數(shù)類型
說明
success
是
int
成功推送的url條數(shù)
remain
是
int
當(dāng)天剩余的可推送url條數(shù)
not_same_site
否
array
由于不是本站url而未處理的url列表
not_valid
否
array
不合法的url列表
成功返回示例:
{
"remain":4999998,
"success":2,
"not_same_site":[],
"not_valid":[]
}
推送失敗
狀態(tài)碼為4xx,返回字段有:
字段
是否必傳
類型
說明
error
是
int
錯(cuò)誤碼,與狀態(tài)碼相同
message
是
string
錯(cuò)誤描述
失敗返回示例:
{
"error":401,
"message":"token is not valid"
}
2、
第二種是發(fā)布一篇文章,就像百度推送一次,這種比較方便,我就是用這種
打開織夢(mèng)后臺(tái)的 article_add.php 文件.找到差不多262行的樣子
注意:如果你系統(tǒng)設(shè)置的-》核心選項(xiàng)
,如果是否直接
加入以下代碼,否則 注意下面的提示
$urls="http://www.youwujun.com.cn".$artUrl;//前面域名換成你自己的 如果上面圖片選擇的是是 就把"http://www.youwujun.com.cn". 去掉
$urls = explode(",",$urls);
$api = 'http://data.zz.baidu.com/urls?site=www.youwujun.com.cn&token=xxxx'; // 前邊site換成自己的site xxx換成自己的密鑰
$ch = curl_init();
$options = array(
CURLOPT_URL => $api,
CURLOPT_POST => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_POSTFIELDS => implode(" ", $urls),
CURLOPT_HTTPHEADER => array('Content-Type: text/plain'),
);
curl_setopt_array($ch, $options);
$result = curl_exec($ch);
就OK了 ,如果想看添加成功沒,可以在修改下面一兩行的樣子的代碼
請(qǐng)選擇你的后續(xù)操作".$result.$urls[0].":
result是看百度返回的結(jié)果,urls是看你推送的url.
基本上就OK了,如果你想讓修改文章的時(shí)候也事實(shí)推送,就類似我上面一樣去修改article_edit.php就好了.
標(biāo)簽: