有時我們在做虛擬靜態化或者讓路徑看起來很漂亮的時候,可能會看到http://www.example.com/index.php/html1這樣URL地址,而在訪問的實際是根目錄下的index.php文件,而把 " /> 黄色片a,亚洲国产第一页,成人欧美一区二区三区黑人免费

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

APACHE的AcceptPathInfo指令使用介紹

學習zfdemo的時候提到設置 AcceptPathInfo 指令.

有時我們在做虛擬靜態化或者讓路徑看起來很漂亮的時候,可能會看到http://www.example.com/index.php/html1這樣URL地址,而在訪問的實際是根目錄下的index.php文件,而把/html1做為PATH_INFO環境變量傳遞給腳本。而對于apache來說上面的地址能否正確運行取決于AcceptPathInfo指令的配置

AcceptPathInfo 指令

說明 是否接受附帶多余路徑名信息的請求
語法 AcceptPathInfo On|Off|Default
默認值 AcceptPathInfo Default
作用域 server config, virtual host, directory, .htaccess
覆蓋項 FileInfo
狀態 核心(C)
模塊 core
兼容性 僅在 Apache 2.0.30 及以后的版本中可用

此指令決定是否接受在實際文件名(或實際目錄中一個不存在的文件)后跟隨多余路徑名信息的請求。這個多余的路徑名信息可以當作PATH_INFO環境變量傳遞給腳本。

比如說,假設/test/所指向的目錄下只包括一個文件:here.html ,那么對/test/here.html/more和/test/nothere.html/more的請求都會將PATH_INFO環境變量設為"/more"。

AcceptPathInfo指令的取值范圍:

Off
僅當一個請求映射到一個真實存在的路徑時,才會被接受。這樣,如上述/test/here.html/more這樣在真實文件名后跟隨一個路徑名的請求將會返回一個"404 NOT FOUND"錯誤。
On
只要前導路徑可以映射到一個真實存在的文件,就可以接受該請求。這樣,只要上述/test/here.html能夠映射到一個有效的文件,那么對/test/here.html/more的請求就會被接收。
Default
是否接收附帶多余路徑名信息的請求由其對應的處理器來決定。對應普通文本的核心處理器默認會拒絕PATH_INFO 。而用于伺服腳本的處理器,比如cgi-script和isapi-isa,默認會接受PATH_INFO 。
AcceptPathInfo指令存在的首要目的就是允許您覆蓋處理器關于是否接受PATH_INFO的默認設置。這種覆蓋是很必要的。比如說,當您使用了類似INCLUDES這樣的過濾器來根據PATH_INFO產生內容時。核心處理器通常會拒絕這樣的請求,而您就可以用下述的配置使這樣的腳本成為可能:

Options +Includes
SetOutputFilter INCLUDES
AcceptPathInfo On

apache 2.0以上中的默認的是沒有acceptpathinfo

從APACH2.0.30以上服務器中去掉了acceptpathinfo;如果需要的話需要在http.conf中添加AcceptPathInfo On這一條。即原來的

Options FollowSymLinks includes
AllowOverride None
改成
Options FollowSymLinks includes
AllowOverride None
 AcceptPathInfo On

此指令決定了是否接受包含在某確定文件(或是某現有目錄的一個不存在的文件)后附加的路徑信息。此路徑信息將在腳本里以PATH_INFO環境變量的形式出現。
比如說,假設/test/所指向的目錄下只包括一個文件:here.html。那么對/test/here.html/more和/test/nothere.html/more的請求都會得到/more這樣的PATH_INFO變量。
AcceptPathInfo指令的三個參數為:
off
僅當一個請求映射到一個真實存在的路徑時,它才會被接受。這樣,如上述/test/here.html/more這樣的在真實文件名后跟隨一個路徑名的請求將會返回一個404 NOT FOUND錯誤。
on
如果前面的路徑映射到一個真實存在的文件,此請求將被接受。如果/test/here.html映射著一個有效的文件,上例中/test/here.html/more這個請求就會被接受。
default
對于附加路徑名的請求的處理方式由其對應的處理器來決定。對應普通文本的核心處理器默認會拒絕PATH_INFO。而用于伺服腳本的處理器,比如cgi-script和isapi-isa,默認會接受PATH_INFO。

php中的全局變量$_SERVER['PATH_INFO']是一個很有用的參數,眾多的CMS系統在美化自己的URL的時候,都用到了這個參數。

對于下面這個網址:
http://www.test.com/index.php/foo/bar.html?c=index&m=search
我們可以得到 $_SERVER['PATH_INFO'] = ‘/foo/bar.html',而此時 $_SERVER['QUERY_STRING'] = 'c=index&m=search';
通常,我們最初開始php程序編寫的時候,都會使用諸如: http://www.test.com/index.php?c=search&m=main 這樣的URL,這種URL不僅看起來非常奇怪,而且對于搜索引擎也是非常不友好的。很多搜索引擎收錄的時候,都會忽略Query String之后的內容,google雖然不會忽略Query String,但是對于其他不含Query String的頁面,會給于比較高的PR值。

下面是一段解析PATH_INFO的非常簡單的代碼:

復制代碼 代碼如下:
<?php
if( !isset( $_SERVER['PATH_INFO'] ) ){
$pathinfo = 'default';
}else{
$pathinfo = explode('/', $_SERVER['PATH_INFO']);
}
if( is_array($pathinfo) AND !empty($pathinfo) ){
$page = $pathinfo[1];
}else{
$page = 'a.php';
}
require "$page.php";
?>


php文件名后加斜線“/”不能正常訪問,報not found錯誤
系統壞后,重裝系統后,配置php環境。用的軟件和以前的版本都相同。

環境配置好后,因工作項目都是單入口文件,index.php文件后邊加了斜線才能進入。沒換系統前都可以訪問,可以排除軟件版本問題.

剛想進入工作項目,就報not found 不知為何。測試后得知,php文件名后加斜線“/”不能正常訪問

詢問多人,未果。google 度娘 未果

找公司一資深php工程師
說是apache有這樣一個指令 :AcceptPathInfo

在apache的配置文件里面加上:AcceptPathInfo on 就ok了。

php技術APACHE的AcceptPathInfo指令使用介紹,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 色婷婷在线播放 | 久久九九综合 | 色网在线免费观看 | 中文字幕在线精品视频万部 | 美女被男人扒开下面无遮无挡 | 亚洲欧美色视频 | 就色干综合| 国产乱论视频 | 丝袜诱惑一区二区 | 久久久国产精品va麻豆 | 国产欧美日韩综合精品一区二区三区 | 亚洲欧美国产日产综合不卡 | 一本色道 | 精品一区二区91 | 免费看黄色的视频 | 高清不卡一区二区三区 | 亚洲一区www | 97se视频| 色综合久久中文 | 国产视频一 | 婷婷久久综合九色综合九七 | 黄色免费网站在线观看 | 91久久综合| 色哟在线| 好吊操视频在线 | 永久黄网站色视频免费 | 亚洲欧美在线免费观看 | 亚洲丶国产丶欧美一区二区三区 | 成人欧美视频在线观看 | 韩国一级成a人片在线观看 韩国一级毛片 | 国产乱码精品一区二区三区中 | 亚洲国产夜色在线观看 | 色呦呦在线观看视频 | 狠狠综合网 | 精品日韩在线 | 青青草伊人久久 | 亚洲第99页 | 国产91久久久久久久免费 | 大jjjj免费看视频 | 国产综合精品久久亚洲 | 久久综合香蕉久久久久久久 |