注:在 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...