php偽靜態
來源:互聯網
上載者:User
我們應該選擇偽靜態還是真靜態
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偽靜態實現四法:
1 <?php
2 //偽靜態方法一
3
4 // localhost/php100/test.php?id|1@action|2
5 $Php2Html_FileUrl = $_SERVER["REQUEST_URI"];
6 echo $Php2Html_FileUrl."<br>";// /php100/test.php?id|1@action|2
7 $Php2Html_UrlString = str_replace("?","",str_replace("/", "", strrchr(strrchr($Php2Html_FileUrl, "/"),"?")));
8 echo $Php2Html_UrlString."<br>";// id|1@action|2
9 $Php2Html_UrlQueryStrList = explode("@", $Php2Html_UrlString);
10 print_r($Php2Html_UrlQueryStrList);// Array ( [0] => id|1 [1] => action|2 )
11 echo "<br>";
12 foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr)
13 {
14 $Php2Html_TmpArray = explode("|", $Php2Html_UrlQueryStr);
15 print_r($Php2Html_TmpArray);// Array ( [0] => id [1] => 1 ) ; Array ( [0] => action [1] => 2 )
16 echo "<br>";
17 $_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpArray[1];
18 }
19 //echo '假靜態:$_GET變數<br />';
20 print_r($_GET); // Array ( [id|1@action|2] => [id] => 1 [action] => 2 )
21 echo "<br>";
22 echo "<hr>";
23 echo $_GET[id]."<br>";// 1
24 echo $_GET[action];// 2
25 ?>
26
1 <?php
2 //偽靜態方法二
3
4 // localhost/php100/test.php/1/2
5 $filename = basename($_SERVER['SCRIPT_NAME']);
6 echo $_SERVER['SCRIPT_NAME']."<br>";// /php100/test.php
7 echo $filename."<br>";// test.php
8
9 if(strtolower($filename)=='test.php'){
10 if(!empty($_GET[id])){
11 $id=intval($_GET[id]);
12 echo $id."<br>";
13 $action=intval($_GET[action]);
14 echo $action."<br>";
15 }else{
16 $nav=$_SERVER['REQUEST_URI'];
17 echo "1:".$nav."<br>";// /php100/test.php/1/2
18 $script=$_SERVER['SCRIPT_NAME'];
19 echo "2:".$script."<br>";// /php100/test.php
20 $nav=ereg_replace("^$script","",urldecode($nav));
21 echo $nav."<br>"; // /1/2
22 $vars=explode("/",$nav);
23 print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 )
24 echo "<br>";
25 $id=intval($vars[1]);
26 $action=intval($vars[2]);
27 }
28 echo $id.'&'.$action;
29 }
30 ?>
31
1 <?php
2 //偽靜態方法三
3
4
5 function mod_rewrite(){
6 global $_GET;
7 $nav=$_SERVER["REQUEST_URI"];
8 echo $nav."<br>";
9 $script_name=$_SERVER["SCRIPT_NAME"];
10 echo $script_name."<br>";
11 $nav=substr(ereg_replace("^$script_name","",urldecode($nav)),1);
12 echo $nav."<br>";
13 $nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//這句是去掉尾部的.html或.htm
14 echo $nav."<br>";
15 $vars = explode("/",$nav);
16 print_r($vars);
17 echo "<br>";
18 for($i=0;$i<Count($vars);$i+=2){
19 $_GET["$vars[$i]"]=$vars[$i+1];
20 }
21 return $_GET;
22 }
23 mod_rewrite();
24 $year=$_GET["year"];//結果為'2006'
25 echo $year."<br>";
26 $action=$_GET["action"];//結果為'_add'
27 echo $action;
28 ?>
29
1 <?php
2 //偽靜態方法四
3
4 //利用server變數 取得PATH_INFO資訊 該例中為 /1,100,8630.html 也就是執行指令碼名後面的部分
5 if(@$path_info =$_SERVER["PATH_INFO"]){
6 //正則匹配一下參數
7 if(preg_match("/\/(\d+),(\d+),(\d+)\.html/si",$path_info,$arr_path)){
8 $gid =intval($arr_path[1]); //取得值 1
9 $sid =intval($arr_path[2]); //取得值100
10 $softid =intval($arr_path[3]); //取得值8630
11 }else die("Path:Error!");
12 //相當於soft.php?gid=1&sid=100&softid=8630
13 }else die('Path:Nothing!');
14 ?>