PHP擷取當期前運作檔案的路徑,名字,伺服器路徑

來源:互聯網
上載者:User
PHP擷取當期前運行檔案的路徑,名字,伺服器路徑

echo "顯示指令檔的相對路徑和檔案名稱:\"".$_SERVER["PHP_SELF"]."\"
";
echo "顯示伺服器使用的CGI指令碼規範:\"".$_SERVER["GATEWAY_INTERFACE"]."\"
";
echo "顯示當前運行指令碼所在伺服器的IP地址:\"".$_SERVER["SERVER_ADDR"]."\"
";
echo "顯示當前運行指令碼伺服器名稱:\"".$_SERVER["SERVER_NAME"]."\"
";
echo "顯示當前運行指令碼伺服器標識:\"".$_SERVER["SERVER_SOFTWARE"]."\"
";
echo "顯示請求頁面的通訊協定的名稱和版本:\"".$_SERVER["SERVER_PROTOCOL"]."\"
";
echo "顯示訪問頁面的要求方法:\"".$_SERVER["REQUEST_METHOD"]."\"
";
echo "顯示指令碼開始已耗用時間:\"".$_SERVER["REQUEST_TIME"]."\"
";
echo "顯示URL問號後的字串:\"".$_SERVER["QUERY_STRING"]."\"
";
echo "顯示當前運行指令碼的主目錄:\"".$_SERVER["DOCUMENT_ROOT"]."\"
";
echo "顯示當前Accept請求的頭資訊:\"".$_SERVER["HTTP_ACCEPT"]."\"
";
echo "顯示當前請求的字元資訊:\"".$_SERVER["HTTP_ACCEPT_CHARSET"]."\"
";
echo "顯示當前當前請求的Accept-Encoding頭資訊:\"".$_SERVER["HTTP_ACCEPT_ENCODING"]."\"
";
echo "顯示當前請求的Accept-Language頭資訊:\"".$_SERVER["HTTP_ACCEPT_LANGUAGE"]."\"
";
echo "顯示當前請求的Connection頭資訊:\"".$_SERVER["HTTP_CONNECTION"]."\"
";
echo "顯示當前請求的Host頭資訊:\"".$_SERVER["HTTP_HOST"]."\"
";
echo "顯示當前頁面的前一個頁面的URL地址:\"".$_SERVER["HTTP_REFERER"]."\"
";
echo "顯示當前請求的User-Agent的頭資訊:\"".$_SERVER["HTTP_USER_AGENT"]."\"
";
echo "顯示指令碼是否可以通過HTTPS協議進行訪問:\"".$_SERVER["HTTPS"]."\"
";
echo "顯示瀏覽當前頁面使用者的IP地址:\"".$_SERVER["REMOTE_ADDR"]."\"
";
echo "顯示瀏覽當前頁面使用者的主機名稱:\"".$_SERVER["REMOTE_HOST"]."\"
";
echo "顯示使用者串連到伺服器時所使用的連接埠:\"".$_SERVER["REMOTE_PORT"]."\"
";
echo "顯示當前執行指令碼的絕對路徑名:\"".$_SERVER["SCRIPT_FILENAME"]."\"
";
echo "顯示Apache設定檔中的SERVER_ADMIN參數設定情況:\"".$_SERVER["SERVER_ADMIN"]."\"
";
echo "顯示網路伺服器使用的連接埠,預設為\"80\":\"".$_SERVER["SERVER_PORT"]."\"
";
echo "顯示伺服器版本和虛擬機器主機名的字串:\"".$_SERVER["SERVER_SIGNATURE"]."\"
";
echo "顯示指令碼在檔案系統中的基本路徑:\"".$_SERVER["PATH_TRANSLATED"]."\"
";
echo "顯示當前指令碼的路徑:\"".$_SERVER["SCRIPT_NAME"]."\"
";
echo "顯示訪問當前頁面的URI:\"".$_SERVER["REQUEST_URI"]."\"
";
?>

注:?在 PHP 4.1.0 及以後版本使用。之前的版本,使用?$HTTP_SERVER_VARS。

$_SERVER?是一個包含諸如頭資訊(header)、路徑(path)和指令碼位置(script locations)的數組。數組的實體由 網頁伺服器建立。不能保證所有的伺服器都能產生所有的資訊;伺服器可能忽略了一些資訊,或者產生了一些未在下面列出的新的資訊。這意味著,大量的這些變數在 CGI 1.1 規範中說明,所以應該仔細研究一下。

這是一個“superglobal”,或者可以描述為自動全域變數。這隻不過意味這它在所有的指令碼中都有效。在函數或方法中不需要使用?global $_SERVER;?訪問它,就如同使用?$HTTP_SERVER_VARS?一樣。

$HTTP_SERVER_VARS?包含著同樣的資訊,但是不是一個自動全域變數(注意:$HTTP_SERVER_VARS?和$_SERVER?是不同的變數,PHP 處理它們的方式不同)。

如果設定了 register_globals 指令,這些變數也在所有指令碼中可用;也就是,分離了?$_SERVER?和$HTTP_SERVER_VARS?數組。相關資訊,請參閱安全的相關章節使用 Register Globals。這些單獨的全域變數不是自動全域變數。

或許會發現下面列出的某些 $_SERVER 元素並不可用。注意,如果以命令列方式運行 PHP,下面列出的元素幾乎沒有有效(或是沒有任何實際意義的)。

?

?

“PHP_SELF”

當前正在執行指令碼的檔案名稱,與 document root 相關。舉例來說,在 URL 地址為http://example.com/test.php/foo.bar?的指令碼中使用?$_SERVER['PHP_SELF']?將會得到/test.php/foo.bar?這個結果。__FILE__ 常量包含當前(例如包含)檔案的絕對路徑和檔案名稱。

如果 PHP 以命令列方式運行,該變數在 PHP 4.3.0 之前無效。

“argv”

傳遞給該指令碼的參數。當指令碼運行在命令列方式時,argv 變數傳遞給程式 C 語言樣式的命令列參數。當調用 GET 方法時,該變數包含請求的資料。

“argc”

包含傳遞給程式的命令列參數的個數(如果運行在命令列模式)。

“GATEWAY_INTERFACE”

伺服器使用的 CGI 規範的版本。例如,“CGI/1.1”。

“SERVER_NAME”

當前運行指令碼所在伺服器主機的名稱。如果該指令碼運行在一個虛擬機器主機上,該名稱是由那個虛擬機器主機所設定的值決定。

“SERVER_SOFTWARE”

伺服器標識的字串,在響應請求時的頭資訊中給出。

“SERVER_PROTOCOL”

請求頁面時通訊協定的名稱和版本。例如,“HTTP/1.0”。

“REQUEST_METHOD”

訪問頁面時的要求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

注:?如果請求的方式是?HEAD,PHP 指令碼將在送出頭資訊後中止(這意味著在產生任何輸出後,不再有輸出緩衝)。

“REQUEST_TIME”

請求開始時的時間戳記。從 PHP 5.1.0 起有效。

“QUERY_STRING”

查詢(query)的字串(URL 中第一個問號 ? 之後的內容)。

“DOCUMENT_ROOT”

當前運行指令碼所在的主目錄。在伺服器設定檔中定義。

“HTTP_ACCEPT”

當前請求的?Accept:?頭資訊的內容。

“HTTP_ACCEPT_CHARSET”

當前請求的?Accept-Charset:?頭資訊的內容。例如:“iso-8859-1,*,utf-8”。

“HTTP_ACCEPT_ENCODING”

當前請求的?Accept-Encoding:?頭資訊的內容。例如:“gzip”。

“HTTP_ACCEPT_LANGUAGE”

當前請求的?Accept-Language:?頭資訊的內容。例如:“en”。

“HTTP_CONNECTION”

當前請求的?Connection:?頭資訊的內容。例如:“Keep-Alive”。

“HTTP_HOST”

當前請求的?Host:?頭資訊的內容。

“HTTP_REFERER”

連結到當前頁面的前一頁面的 URL 地址。不是所有的使用者代理程式(瀏覽器)都會設定這個變數,而且有的還可以手工修改?HTTP_REFERER。因此,這個變數不總是真實正確的。

“HTTP_USER_AGENT”

當前請求的?User-Agent:?頭資訊的內容。該字串表明了訪問該頁面的使用者代理程式的資訊。一個典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。也可以使用?get_browser()?得到此資訊。

“HTTPS”

如果指令碼是通過 HTTPS 協議被訪問,則被設為一個非空的值。

“REMOTE_ADDR”

正在瀏覽當前頁面使用者的 IP 位址。

“REMOTE_HOST”

正在瀏覽當前頁面使用者的主機名稱。反向網域名稱解析基於該使用者的?REMOTE_ADDR。

注:?必須配置 Web 服務器來建立此變數。例如 Apache 需要在?httpd.conf?中有HostnameLookups On。參見?gethostbyaddr()

“REMOTE_PORT”

使用者串連到伺服器時所使用的連接埠。

“SCRIPT_FILENAME”

當前執行指令碼的絕對路徑名。

注:?如果指令碼在 CLI 中被執行,作為相對路徑,例如?file.php?或../file.php,$_SERVER['SCRIPT_FILENAME']?將包含使用者指定的相對路徑。

?

“SERVER_ADMIN”

該值指明了 Apache 伺服器設定檔中的 SERVER_ADMIN 參數。如果指令碼運行在一個虛擬機器主機上,則該值是那個虛擬機器主機的值。

“SERVER_PORT”

伺服器所使用的連接埠。預設為“80”。如果使用 SSL 安全連線,則這個值為使用者佈建的 HTTP 連接埠。

“SERVER_SIGNATURE”

包含伺服器版本和虛擬機器主機名的字串。

“PATH_TRANSLATED”

當前指令碼所在檔案系統(不是主目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。

注:?PHP 4.3.2 之後,PATH_TRANSLATED?在 Apache 2?SAPI?模式下不再和 Apache 1 一樣隱含賦值,而是若 Apache 不產生此值,PHP 便自己產生並將其值放入?SCRIPT_FILENAME?伺服器常量中。這個修改遵守了?CGI?規範,PATH_TRANSLATED?僅在?PATH_INFO?被定義的條件下才存在。

Apache 2 使用者可以使用?httpd.conf?中的?AcceptPathInfo On?來定義?PATH_INFO。

“SCRIPT_NAME”

包含當前指令碼的路徑。這在頁面需要指向自己時非常有用。__FILE__ 包含當前檔案的絕對路徑和檔案名稱(例如包含檔案)。

“REQUEST_URI”

訪問此頁面所需的 URI。例如,“/index.html”。

“PHP_AUTH_DIGEST”

當作為 Apache 模組運行時,進行 HTTP Digest 認證的過程中,此變數被設定成用戶端發送的“Authorization”HTTP 頭內容(以便作進一步的認證操作)。

“PHP_AUTH_USER”

當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的使用者名稱。

“PHP_AUTH_PW”

當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模組方式下,並且正在使用 HTTP 認證功能,這個變數便是使用者輸入的密碼。

“AUTH_TYPE”

當 PHP 運行在 Apache 模組方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.