php伪静态

巴扎黑
巴扎黑original
2016-11-22 16:10:031215parcourir

我们应该选择伪静态还是真静态 
      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 2 //伪静态方法一
3
4 // localhost/php100/test.php?id|1@action|2
5 $Php2Html_FileUrl = $_SERVER["REQUEST_URI"];
6 echo $Php2Html_FileUrl."
";// /php100/test.php?id|1@action|2 
7  $Php2Html_UrlString = str_replace("?","",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] => id|1 [1] => action|2 ) 
11  echo "
"; 
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 "
"; 
17  $_GET[$Php2Html_TmpArray[0]] = $Php2Html_TmpArray[1]; 
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]."
";// 1 
24  echo $_GET[action];// 2 
25  ?> 
26  

1 2  //伪静态方法二 

4 // localhost/php100/test.php/1/2 
5  $filename = basename($_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($_GET[id]); 
12   echo $id."
"; 
13   $action=intval($_GET[action]); 
14   echo $action."
"; 
15  }else{ 
16   $nav=$_SERVER['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   echo $nav."
"; // /1/2 
22    $vars=explode("/",$nav); 
23   print_r($vars);// Array ( [0] => [1] => 1 [2] => 2 ) 
24    echo "
"; 
25   $id=intval($vars[1]); 
26   $action=intval($vars[2]); 
27  } 
28  echo $id.'&'.$action; 
29 } 
30  ?> 
31  

1 2 //伪静态方法三 


5 function mod_rewrite(){ 
6 global $_GET; 
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($nav)),1); 
12 echo $nav."
"; 
13 $nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//这句是去掉尾部的.html或.htm 
14 echo $nav."
"; 
15 $vars = explode("/",$nav); 
16 print_r($vars); 
17 echo "
"; 
18 for($i=0;$i19 $_GET["$vars[$i]"]=$vars[$i+1]; 
20 } 
21 return $_GET; 
22 } 
23 mod_rewrite(); 
24 $year=$_GET["year"];//结果为'2006' 
25 echo $year."
"; 
26 $action=$_GET["action"];//结果为'_add' 
27 echo $action; 
28 ?> 
29 

1 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 ?> 

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn