首頁 > 後端開發 > php教程 > 什麼是偽靜態?三種實作PHP偽靜態的方法介紹

什麼是偽靜態?三種實作PHP偽靜態的方法介紹

零下一度
發布: 2023-03-14 13:58:01
原創
11623 人瀏覽過

      偽靜態是相對真實靜態來講的,通常我們為了增強搜尋引擎的友善面,都將文章內容產生靜態頁面,但是有的朋友為了即時的顯示一些資訊。或者還想運用動態腳本解決一些問題。不能用靜態的方式來展示網站內容。但這就損失了對搜尋引擎的友善面。怎麼樣在兩者之間找個中間方法呢,這就產生了偽靜態技術。就是展示出來的是以html一類的靜態頁面形式,但其實是用ASP一類的動態腳本來處理的。

偽靜態又稱為:URL重寫 

# 主要是為了SEO而生的。 (SEO是什麼?這個不用問我吧。呵呵~搞網路的不懂SEO那就~~~~)

## 方法一:

例如這個網頁

# /soft.php/1,100,8630.html

# 其實處理的腳本是soft.php 參數為1,100,8630

相當於soft.php?a=1&b=1=100&c=8630 只不過這樣的URL太難記。搜尋引擎也不喜歡。

真靜態只是完全產生了HTML。

客戶端存取的時候直接輸出。不用腳本解釋。在流量非常大的時候(例如每天有數百萬的訪問量的時候)會起到很好的效果。也就是說伺服器端實實在在的存在這個HTML頁面。

當然在你網站的流量沒有那麼大的時候。 URL重寫是最好的方法(個人觀點,大流量的時候可以考慮負載平衡了。同樣沒有關係)

# 附URL重寫的方法有很多種,APACHE,IISREWRITE。甚至PHP腳本都可以直接處理。例如上例中就是PHP腳本直接處理(該方法好處是大流量的時候直接減輕WEB服務器的壓力。PS:同樣也是個人觀點:

# ================================================

## 下面以程式為例講一下PHP偽靜態的程式實作方法,其實這方法我之前已經有在其它論壇社群發過

程式為例:

/soft.php/1,100,8630.html

# CODE:

# //利用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
登入後複製


//就是這麼簡單了。 ~)

# 方法二:

一 開啟 Apache 的設定檔 httpd.conf 。

二 將#LoadModule rewrite_module modules/mod_rewrite前面的#去掉

三 在 httpd.conf中新增:

<IfModule mod_rewrite.c>RewriteEngine On#RewriteCond %{ENV:SCRIPT_URL} (?:index|dispbbs)[-0-9]+.htmlRewriteRule ^(.*?(?:index|dispbbs))-([-0-9]+).html 1.php?__is_apache_rewrite=1&__rewrite_arg=2</IfModule>
四 要实现asp帖子URL到php帖子的映射,在 第三步的<IfModule mod_rewrite.c>和</IfModule>之间添加:
RewriteMap tolowercase int:tolowerRewriteCond %{QUERY_STRING} (?:boardid|page|id|replyid|star|skin)=d+ [NC]RewriteRule ^(.*(?:index|dispbbs)).asp 1.php?{tolowercase:%{QUERY_STRING}}&__is_apache_rewrite=1
登入後複製

五 儲存httpd.conf並重啟Apache

方法三:

<?php/*功能:PHP伪静态化页面的实现具体用法:例如链接为:test.php/year/2006/action/_add.htmlmod_rewrite();$yearn=$_GET["year"];//结果为&#39;2006&#39;$action=$_GET["action"];//结果为&#39;_add&#39;
*/function mod_rewrite(){global $_GET;$nav=$_SERVER["REQUEST_URI"];$script_name=$_SERVER["SCRIPT_NAME"];$nav=substr(ereg_replace("^$script_name","",urldecode($nav)),1);$nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//这句是去掉尾部的.html或.htm$vars = explode("/",$nav);for($i=0;$i<Count($vars);$i+=2){$_GET["$vars[$i]"]=$vars[$i+1];}return $_GET;}mod_rewrite();$yearn=$_GET["year"];//结果为&#39;2006&#39;$action=$_GET["action"];//结果为&#39;_add&#39;echo $yearn;echo $action;?>
<?php/*
登入後複製

功能:PHP偽靜態化頁面的實作
具體用法:
例如連結為:test.php/year/2006/action/_add.html

mod_rewrite();$yearn=$_GET["year"];//结果为&#39;2006&#39;$action=$_GET["action"];//结果为&#39;_add&#39;
*/function mod_rewrite(){global $_GET;$nav=$_SERVER["REQUEST_URI"];$script_name=$_SERVER["SCRIPT_NAME"];$nav=substr(ereg_replace("^$script_name","",urldecode($nav)),1);$nav=preg_replace("/^.ht(m){1}(l){0,1}$/","",$nav);//这句是去掉尾部的.html或.htm$vars = explode("/",$nav);for($i=0;$i<Count($vars);$i+=2){$_GET["$vars[$i]"]=$vars[$i+1];}return $_GET;}mod_rewrite();$yearn=$_GET["year"];//结果为&#39;2006&#39;$action=$_GET["action"];//结果为&#39;_add&#39;echo $yearn;echo $action;?>
登入後複製

以上是什麼是偽靜態?三種實作PHP偽靜態的方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板