基於php偽靜態的實現方法解析
一直在做php的開發工作.在開發的過程中老早就聽說了“偽靜態”這一說。但是一直沒有對其進行了解。
今天終於下定決定 要好好的瞭解下這方面的內容。
首先,什麼是偽靜態:
偽靜態又名URL重寫,是動態的網址看起來像靜態的網址。換句話說就是,動態網頁通過重寫URL方法實現去掉動態網頁的引數,但在實際的網頁目錄中並沒有必要實現存在重寫的頁面。
另外在補充兩個名詞解析
靜態網址:純靜態HTML文件,能使用filetype:htm 查詢到的網頁
動態網址:內容存於資料庫中,根據要求顯示內容,URL中以 ? # & 顯示不同的引數,如:news.php?lang=cn&class=1&id=2
動態、靜態、偽靜態之間的利與弊(新)
動態網址
首先,動態網址目前對於Google來說,“不能被抓取”的說法是錯誤的,Google能夠很好的處理動態網址並順利抓取;其次“引數不能超過3個”的說法也不正確,Google能夠抓取引數超過3個的動態網址,不過,為了避免URL太長應儘量減少引數。
其次,動態網址有其一定的優勢,以上面所說的 news.php?lang=cn&class=1&id=2 為例,網址中的引數準確的告訴Google,此URL內容語言為cn、隸屬於分類1、內容ID為2,更便於Google對內容的識別處理。
最後,動態網址應儘量精簡,特別是會話標識(sid)和查詢(query)引數,容易造成大量相同頁面。
靜態網址
首先,靜態網址具有的絕對優勢是其明晰,/product/nokia/n95.html和/about.html可以很容易被理解,從而在搜尋結果中可能點選量相對較高。
其次,靜態網址未必就是最好的網址形式,上述動態網址中說到,動態網址能夠告訴Google一些可以識別的引數,而靜態網址如果文件佈置不夠恰當(如:過於扁平化,將HTML文件全放在根目錄下)及其他因素,反而不如靜態網址為Google提供的參考資訊豐富。
最後,樂思蜀覺得Google此文中是否有其隱藏含義?“更新此種類型網址的頁面會比較耗費時間,尤其是當資訊量增長很快時,因為每一個單獨的頁面都必須更改編譯程式碼。”雖然所說的是網站,但在Google系統中是否同樣存在這樣的問題呢?
偽靜態網址
首先,偽靜態網址不能讓動態網址“靜態化”,偽靜態僅僅是對動態網址的一個重寫,Google不會認為偽靜態就是HTML文件。
其次,偽靜態可取,但應把重心放在去除冗餘引數、規範URL、儘可能的避免重複頁上。
最後,偽靜態有很大潛大危險,最好在對網站系統、網站結構、內容分佈、引數意義熟悉的情況下使用。
在寫偽靜態規則時,應保留有價值的引數,不要將有價值的引數全部精簡掉,如前面例子中的 news.php?lang=cn&class=1&id=2 最好重寫為 news-cn-class1-id2.html,而不是過份精簡重寫為 news-2.html。
再就是偽靜態中一定不能包含會話標識(sid)和查詢(query)引數,/product.asp?sid=98971298178906&id=1234 這樣的動態網址,其中的sid本來Google能夠識別並遮蔽,但如果重寫為 /product/98971298178906/1234,Google不但無法識別,還在整站中造成無限重複頁面(每個會話都會產生一個新的會話ID)。
我們應該選擇偽靜態還是真靜態
1、使用真靜態和假靜態對SEO來說沒有什麼區別
2、使用真靜態可能將導致硬碟損壞並將影響論壇效能
3、使用偽靜態將佔用一定量的CPU佔有率,大量使用將導致CPU超負荷
4、最重要的一點,我們要靜態是為了SEO
所以:
1、使用真靜態的方法可以直接排除了,因為無論怎麼生成,對硬碟來說都是很傷的。
2、既然真偽靜態的效果一樣,我們就可以選擇偽靜態了。
3、但是偽靜態大量使用會造成CPU超負荷。
4、所以我們只要不大量使用就可以了。
5、既然靜態只是給SEO看的,我們只需要偽靜態給SEO就行了,不需要給使用者使用。
6、所以我們只要在專門提供給SEO爬的Archiver中使用偽靜態就可以了。
7、謝謝大家耐心看我寫的文章。
8、有何不解的地方或是有不同的看法歡迎提出
關於偽靜態和真靜態的評論
真正的靜態化和偽靜態還是有本質的區別的。為瀏覽使用者處理一個純粹html和一個呼叫多個數據的php在CPU的使用率方面明顯前者少。記得原來有個人說html下載硬碟讀寫頻繁,他這麼說好像讀取資料庫不用讀寫磁碟似的,何況還有一大堆快取的零散php也是放在硬碟的,這些讀取不用磁碟操作麼?可笑。
讀取單個html+圖片Flash等附件就可以實現的目的,何苦要讀資料庫又要讀php快取檔案又要重新整合資料輸出再+圖片Flash等附件這麼大費周章呢?CMS首頁不需要很多的互動的,論壇那一套不應該拿到這裡來用,相反應該更多考慮的是:美觀!相容!資訊的直觀!效能!還有穩定!
在轉一個 php偽靜態的實現四法:
<?php //偽靜態方法一 // localhost/php100/test.php?id|1@action|2 $Php2Html_FileUrl = $_SERVER["REQUEST_URI"]; echo $Php2Html_FileUrl."<br>";// /php100/test.php?id|1@action|2 $Php2Html_UrlString = str_replace("?","",str_replace("/",strrchr(strrchr($Php2Html_FileUrl,"/"),"?"))); echo $Php2Html_UrlString."<br>";// id|1@action|2 $Php2Html_UrlQueryStrList = explode("@",$Php2Html_UrlString); print_r($Php2Html_UrlQueryStrList);// Array ( [0] => id|1 [1] => action|2 ) echo "<br>"; foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr) { $Php2Html_TmpArray = explode("|",$Php2Html_UrlQueryStr); print_r($Php2Html_TmpArray);// Array ( [0] => id [1] => 1 ) ; Array ( [0] => action [1] => 2 ) echo "<br>"; $_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpArray[1]; } //echo '假靜態:$_GET變數<br />'; print_r($_GET); // Array ( [id|1@action|2] => [id] => 1 [action] => 2 ) echo "<br>"; echo "<hr>"; echo $_GET[id]."<br>";// 1 echo $_GET[action];// 2 ?>
<?php //偽靜態方法二 // localhost/php100/test.php/1/2 $filename = basename($_SERVER['SCRIPT_NAME']); echo $_SERVER['SCRIPT_NAME']."<br>";// /php100/test.php echo $filename."<br>";// test.php if(strtolower($filename)=='test.php'){ if(!empty($_GET[id])){ $id=intval($_GET[id]); echo $id."<br>"; $action=intval($_GET[action]); echo $action."<br>"; }else{ $nav=$_SERVER['REQUEST_URI']; echo "1:".$nav."<br>";// /php100/test.php/1/2 $script=$_SERVER['SCRIPT_NAME']; echo "2:".$script."<br>";// /php100/test.php $nav=ereg_replace("^$script",urldecode($nav)); echo $nav."<br>"; // /1/2 $vars=explode("/",$nav); print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 ) echo "<br>"; $id=intval($vars[1]); $action=intval($vars[2]); } echo $id.'&'.$action; } ?>
<?php //偽靜態方法三 function mod_rewrite(){ global $_GET; $nav=$_SERVER["REQUEST_URI"]; echo $nav."<br>"; $script_name=$_SERVER["SCRIPT_NAME"]; echo $script_name."<br>"; $nav=substr(ereg_replace("^$script_name",urldecode($nav)),1); echo $nav."<br>"; $nav=preg_replace("/^.ht(m){1}(l){0,1}$/",$nav);//這句是去掉尾部的.html或.htm echo $nav."<br>"; $vars = explode("/",$nav); print_r($vars); echo "<br>"; for($i=0;$i<Count($vars);$i+=2){ $_GET["$vars[$i]"]=$vars[$i+1]; } return $_GET; } mod_rewrite(); $year=$_GET["year"];//結果為'2006' echo $year."<br>"; $action=$_GET["action"];//結果為'_add' echo $action; ?>
<?php //偽靜態方法四 //利用server變數 取得PATH_INFO資訊 該例中為 /1,100,8630.html 也就是執行指令碼名後面的部分 if(@$path_info =$_SERVER["PATH_INFO"]){ //正則匹配一下引數 if(preg_match("/\/(\d+),(\d+),(\d+)\.html/si",$path_info,$arr_path)){ $gid =intval($arr_path[1]); //取得值 1 $sid =intval($arr_path[2]); //取得值100 $softid =intval($arr_path[3]); //取得值8630 }else die("Path:Error!"); //相當於soft.php?gid=1&sid=100&softid=8630 }else die('Path:Nothing!'); ?>
如果不想使用php來實現偽靜態,可是使用 apache,nginx,iis 等伺服器自帶的url rewrite 功能進行設定。
參考資料:
http://baike.baidu.com/view/1570373.htm?fr=ala0_1
http://blog.sina.com.cn/s/blog_4a657b6b0100gdnk.html
http://www.chinaz.com/Webbiz/Exp/01041029142010.html
http://apps.hi.baidu.com/share/detail/5308118
到此這篇關於基於php偽靜態的實現方法解析的文章就介紹到這了,更多相關php偽靜態的實現內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!