php伪静态

WBOY
Libérer: 2016-06-23 14:34:31
original
1131 Les gens l'ont consulté

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

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

首先,什么是伪静态:

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

 

另外在补充两个名词解析

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

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

 

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

动态网址

首先,动态网址目前对于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伪静态的实现四法:

 

              <p class="sycode">                   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                    </p>
Copier après la connexion

              <p class="sycode">                   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                    </p>
Copier après la connexion

              <p class="sycode">                   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                   </p>
Copier après la connexion

              <p class="sycode">                   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         ?>        15                   </p>
Copier après la connexion

 

如果不想使用php来实现伪静态,可是使用 apache,nginx,iis 等服务器自带的url rewrite 功能进行设置。

 

参考资料:

http://baike.baidu.com/view/1570373.htm?fr=ala0_1#2

http://blog.sina.com.cn/s/blog_4a657b6b0100gdnk.html

http://www.chinaz.com/Webbiz/Exp/01041029142010.html

http://apps.hi.baidu.com/share/detail/5308118

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal