用php實現讓頁面只能被百度gogole蜘蛛訪問的方法
更新時間:2009年12月29日 00:08:10 作者:
用php實現讓頁面只能被百度gogole蜘蛛訪問的方法,需要的朋友可以參考下。
普通用戶與搜索引擎蜘蛛爬行的區(qū)別在于發(fā)送的user agent,
看網站日志文件能發(fā)現百度蜘蛛名字包含Baiduspider, 而google的則是Googlebot, 這樣我們可以通過判斷發(fā)送的user agent來決定要不要取消普通用戶的訪問,編寫函數如下:
function isAllowAccess($directForbidden = FALSE) {
$allowed = array('/baiduspider/i', '/googlebot/i');
$user_agent = $_SERVER['HTTP_USER_AGENT'];
$valid = FALSE;
foreach ($allowed as $pattern) {
if (preg_match($pattern, $user_agent)) {
$valid = TRUE;
break;
}
}
if (!$valid && $directForbidden) {
exit("404 not found");
}
return $valid;
}
在要禁止訪問的頁面頭部引用這個函數來做判斷就ok了,如下倆中調用方式:
if (!isAllowAccess()) {
exit("404 not found");
}
//或者
isAllowAccess(TRUE);
看網站日志文件能發(fā)現百度蜘蛛名字包含Baiduspider, 而google的則是Googlebot, 這樣我們可以通過判斷發(fā)送的user agent來決定要不要取消普通用戶的訪問,編寫函數如下:
復制代碼 代碼如下:
function isAllowAccess($directForbidden = FALSE) {
$allowed = array('/baiduspider/i', '/googlebot/i');
$user_agent = $_SERVER['HTTP_USER_AGENT'];
$valid = FALSE;
foreach ($allowed as $pattern) {
if (preg_match($pattern, $user_agent)) {
$valid = TRUE;
break;
}
}
if (!$valid && $directForbidden) {
exit("404 not found");
}
return $valid;
}
在要禁止訪問的頁面頭部引用這個函數來做判斷就ok了,如下倆中調用方式:
復制代碼 代碼如下:
if (!isAllowAccess()) {
exit("404 not found");
}
//或者
isAllowAccess(TRUE);
相關文章
jQuery+PHP發(fā)布的內容進行無刷新分頁(Fckeditor)
這篇文章主要介紹了jQuery結合,將Fckeditor發(fā)布的內容進行無刷新分頁,需要的朋友可以參考下2015-10-10PHP 執(zhí)行系統(tǒng)外部命令 system() exec() passthru()
PHP作為一種服務器端的腳本語言,象編寫簡單,或者是復雜的動態(tài)網頁這樣的任務,它完全能夠勝任。但事情不總是如此,有時為了實現某個功能,必須借助于操作系統(tǒng)的外部程序(或者稱之為命令),這樣可以做到事半功倍。2009-08-08