解析基于php伪静态的实现方法

解析基于php伪静态的实现方法,第1张

概述解析基于php伪静态的实现方法

一直在做PHP的开发工作.在开发的过程中老早就听说了“伪静态”这一说。但是一直没有对其进行了解。

今天终于下定决定 要好好的了解下这方面的内容。

首先,什么是伪静态:

伪静态又名URL重写,是动态的网址看起来像静态的网址。换句话说就是,动态网页通过重写URL方法实现去掉动态网页的参数,但在实际的网页目录中并没有必要实现存在重写的页面。

另外在补充两个名词解析

静态网址:纯静态HTML文档,能使用filetype:htm 查询到的网页

动态网址:内容存于数据库中,根据要求显示内容,URL中以 ? # & 显示不同的参数,如:news.PHP?lang=cn&class=1&ID=2

相关学习推荐:PHP编程从入门到精通

动态、静态、伪静态之间的利与弊(新)

动态网址

首先,动态网址目前对于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或.htmecho $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功能进行设置。 总结

以上是内存溢出为你收集整理的解析基于php伪静态的实现方法全部内容,希望文章能够帮你解决解析基于php伪静态的实现方法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1014658.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存