首頁 > 後端開發 > php教程 > php偽靜態

php偽靜態

巴扎黑
發布: 2016-11-22 16:10:03
原創
1243 人瀏覽過

我們應該選擇偽靜態還是真靜態 
      1、使用真靜態和假靜態對SEO沒有什麼區別 
  2、使用真靜態可能會導致硬碟損壞並將影響論壇性能 
  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 2  //偽靜態方法一 

4 // localhost/php100/test.php?id|1@action|2 
555 $Php2Html_FileUrl = $_SERVER["REQUEST_URI"]; 
6  echo $Php2Html_FileUrl."
";///php100/test.php?id|1@action|2 

7 . "",str_replace("/", "", strrchr(strrchr($Php2Html_FileUrl, "/"),"?"))); 
8  echo $Php2Html_UrlString."
";// id|1@action |2 
9  $Php2Html_UrlQueryStrList = explode("@", $Php2Html_UrlString); 
10  print_r($Php2Html_UrlQueryStrList);// Array ( [0] =>Php.
"; 
12  foreach($Php2Html_UrlQueryStrList as $Php2Html_UrlQueryStr) 
13 { 
14  $Php2Html_TmpArray = explode("|t, $PQueryr5$Pt Html_TmpArray);// Array ( [0] => id [1] => 1 ) ; Array ( [0] => action [1] => 2 ) 
16  echo "
"; 
17  $_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpPhp2Html_TmpArray[0]] = $Php2Ht_TmpArray[ ; 
18 } 
19  //echo '假靜態:$_GET變數
'; 
20  print_r($_GET); // Array ( [id|1@action|2] => [id] => 1 [action] => 2 ) 
21  echo "
"; 
22  echo "


"; 
23  echo $_GET[id]."
";///24 
24 
24 action];// 2 
25  ?> 
26  

1 2  //偽靜態方法二 

4 // localhost/php100/test二 

4 // localhost/php100/test.phpname/1/ $_SERVER['SCRIPT_NAME']); 
6  echo $_SERVER['SCRIPT_NAME']."
";// /php100/test.php 
7  echo $filename."
";// test. php 
8  
9  if(strtolower($filename)=='test.php'){ 
10  if(!empty($_GET[id])){ 
11  $id=intval(
12   echo $id."
"; 
13   $action=intval($_GET[action]); 
14   echo $action."
"; 
15 14   echo $action."
"; 
15 14   echo $action."
"; 
15 navelse{15 ; ['REQUEST_URI']; 🎜17   echo "1:".$nav."
";// /php100/test.php/1/2 🎜18    $script=$_SERVER['SCRIPT_NAME'];19   echo "2:".$script."
";// /php100/test.php 
20    $nav=ereg_replace("^$script","",urldecode($nav)); 
21  echocho $nav。 "
"; // /1/2 
22    $vars=explode("/",$nav); 
23   print_r($vars);// 陣列( [0] => [1] => 1 [2] => 2 ) 
24    echo "
"; 
25   $id=intval($vars[1]); 
26   $action=intval($vars[2]); 
26   $action=intval($vars[2]); 
26   $action=intval($vars[2]); 
26   $action=intval($vars[2]); 
26   $action=intval($vars[2]); 
27 $id.'&'.$action; 
29 } 
30  ?> 
31  

1 2 //偽靜態方法三 


2 //偽靜態方法三 


2 //偽靜態方法三 


2
7 $nav=$_SERVER["REQUEST_URI"]; 
8 echo $nav。 "
"; 
9 $script_name=$_SERVER["SCRIPT_NAME"]; 
10 echo $script_name."
"; 
11 $nav=substr(ereg_replace("^$script_name",""",urldecode",""",urlde ($nav)),1); 
12 echo $nav."
"; 
13 $nav=preg_replace("/^.ht(m){1}(l){0,1}$/" ,"",$nav);//這句是去掉尾部的.html或.htm
14 echo $nav."
"; 
15 $vars = 爆炸("/",$nav); 
16 print_r($vars); 
17 迴音「
」; 
18 for($i=0;$i19 $_GET["$vars[$i+=2){ 
19 $_GET["$vars[$i ]"]=$vars[$i+1]; 
20 } 
21 回傳$_GET; 
22 } 
23 mod_rewrite(); 
24 $year=$_GET["year"]; ' 
25 echo $year."
"; 
26 $action=$_GET["action"];//結果為'_add' 
27 echo $action; 
28? > 
29 

1 2 //偽靜態方法四 

4 // 利用伺服器標記取得PATH_INFO資訊在此範例中為/1,100,8630.html   孫執行腳本名稱後面的部分中為/1,100,8630.html   孫執行腳本名稱後面的部分@$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])   // 取得值10000001 $arr_path[3]);   // 取得值8630 🎜11 }else die("Path:Error!"); 🎜12 // 相當於soft.php?gid=1&sid=100&softid=8630 🎜130 Path:Nothing!'); 🎜14? > 🎜
相關標籤:
php
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板