我们应该选择伪静态还是真静态
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 ?>
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号