PHP獲取當期前執行檔案的路徑,名字,伺服器路徑

2021-09-01 08:22:34 字數 4236 閱讀 6465

注:在 php 4.1.0 及以後版本使用。之前的版本,使用 $http_server_vars。

$_server 是乙個包含諸如頭資訊(header)、路徑(path)和指令碼位置(script locations)的陣列。陣列的實體由 web 伺服器建立。不能保證所有的伺服器都能產生所有的資訊;伺服器可能忽略了一些資訊,或者產生了一些未在下面列出的新的資訊。這意味著,大量的這些變數在 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 位址為 的指令碼中使用 $_server['php_self'] 將會得到/test.php/foo.bar 這個結果。__file__ 常量包含當前(例如包含)檔案的絕對路徑和檔名。

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

「 argv」

傳遞給該指令碼的引數。當指令碼執行在命令列方式時,argv 變數傳遞給程式 c 語言樣式的命令列引數。當呼叫 get 方法時,該變數包含請求的資料。

「 argc」

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

「 gateway_inte***ce」

伺服器使用的 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」

當前執行指令碼所在的文件根目錄。在伺服器配置檔案中定義。

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

當前請求的 accept-charset: 頭資訊的內容。例如:「iso-8859-1,*,utf-8」。

當前請求的 accept-encoding: 頭資訊的內容。例如:「gzip」。

當前請求的 accept-language: 頭資訊的內容。例如:「en」。

當前請求的 connection: 頭資訊的內容。例如:「keep-alive」。

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

鏈結到當前頁面的前一頁面的 url 位址。不是所有的使用者**(瀏覽器)都會設定這個變數,而且有的還可以手工修改 http_referer。因此,這個變數不總是真實正確的。

當前請求的 user-agent: 頭資訊的內容。該字串表明了訪問該頁面的使用者**的資訊。乙個典型的例子是:mozilla/4.5 [en] (x11; u; linux 2.2.9 i586)。也可以使用get_browser()得到此資訊。

如果指令碼是通過 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 認證功能,這個變數便是認證的型別。

python獲取程式執行檔案路徑的方法 推薦

1 sys.ar 乙個傳給python指令碼的指令引數列表。sys.ar 0 是指令碼的名字。一般得到的是相對路徑,用os.path.abspath sys.ar 0 得到執行檔案的絕對路徑 dirname,filename os.path.split os.path.abspath sys.ar ...

PATH 關於執行檔案路徑的路徑

命令解釋 我們用ls這個命令去舉例,使用whereis ls後,可以看到ls的的完整檔名為 bin ls。你會不會覺的很奇怪,為什麼我可以在任何地方執行此命令呢?那是因為環境變數path的幫助。root localhost ceshi whereis ls ls bin ls usr share m...

delphi 獲取可執行檔案的當前路徑

expandfilename 返回檔案的全路徑 含驅動器 路徑 extractfileext 從檔名中抽取副檔名 extractfilename 從檔名中抽取不含路徑的檔名 extractfilepath 從檔名中抽取路徑名 extractfiledir 從檔名中抽取目錄名 extractfiled...