上一篇文章中我們知道了什麼叫做超級全局變量,了解了$GLOBALS,有需要的請看《小編帶你學變量之php中的$GLOBALS》。這次我們向大家介紹$_SERVER,有需要的可以參考參考。
為了我們了解這個數組,我們來看一個小栗子。
<?php echo $_SERVER['PHP_SELF']; echo "<br>"; echo $_SERVER['SERVER_NAME']; echo "<br>"; echo $_SERVER['HTTP_HOST']; echo "<br>"; echo $_SERVER['HTTP_REFERER']; echo "<br>"; echo $_SERVER['HTTP_USER_AGENT']; echo "<br>"; echo $_SERVER['SCRIPT_NAME']; ?>
結果為
/try/demo_source/demo_global_server.php www.runoob.com www.runoob.com https://www.runoob.com/try/showphp.php?filename=demo_global_server Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/86.0.4240.198 Safari/537.36 /try/demo_source/demo_global_server.php
我們先大致的看一下結果,似乎都是一個位址,那我們就可以大膽猜測一下,這個數組是一個儲存資訊的數組,下面就讓我們去驗證一下。
$_SERVER是一個數組,包含頭資訊(header)、路徑(path)、以及腳本位置(script locations)等資訊。此數組中的項目由網頁伺服器建立。不能保證每台伺服器都會提供所有項目;伺服器可能會忽略某些項目或提供此處未列出的項目。
我們說一下所有 $_SERVER 變數中的重要元素。
$_SERVER['PHP_SELF'],目前執行腳本的檔名,與 document root 有關。例如,在位址為
http://example.com/test.php/foo.bar
的腳本中使用$_SERVER['PHP_SELF']
將會得到/test .php/foo.bar
。 __FILE__ 常數包含目前(例如包含)檔案的完整路徑和檔名。從 PHP 4.3.0 版本開始,如果 PHP 以命令列模式執行,這個變數將包含腳本名稱。之前的版本該變數不可用。$_SERVER['GATEWAY_INTERFACE'],伺服器所使用的 CGI 規範的版本;例如,"
CGI/1.1
」。$_SERVER['SERVER_ADDR'],目前執行腳本所在的伺服器的 IP 位址。
$_SERVER['SERVER_NAME'],目前執行腳本所在的伺服器的主機名稱。如果腳本運行於虛擬主機中,則該名稱是由該虛擬主機所設定的值決定。
$_SERVER['SERVER_SOFTWARE'],伺服器識別字串,在回應請求時的頭資訊中給出。 (如:
Apache/2.2.24
)#$_SERVER['SERVER_PROTOCOL'],要求頁面時通訊協定的名稱和版本。例如,"
HTTP/1.0
"。$_SERVER['REQUEST_METHOD'],存取頁面使用的請求方法;例如,"GET", "HEAD","POST","PUT"。
$_SERVER['REQUEST_TIME'],請求開始時的時間戳記。從
PHP 5.1.0
起可用。 (如:1377687496)$_SERVER['QUERY_STRING'],
query string
(查詢字串),如果有的話,透過它進行頁面存取。$_SERVER['HTTP_ACCEPT'],目前請求頭中 Accept: 項目的內容,如果存在的話。
$_SERVER['HTTP_ACCEPT_CHARSET'],目前請求頭中
Accept-Charset
: 項目的內容,如果存在的話。例如:"iso-8859-1,*,utf-8"。$_SERVER['HTTP_HOST'],目前請求頭中 Host: 項的內容,如果存在的話。
$_SERVER['HTTP_REFERER'],引導使用者代理到目前頁面的前一頁的位址(如果存在)。由
user agent
設定決定。並不是所有的用戶代理都會設定該項,有的還提供了修改HTTP_REFERER
的功能。簡言之,該數值並不可信。 )$_SERVER['HTTPS'],如果腳本是透過 HTTPS 協定被訪問,則被設為一個非空的值。
$_SERVER['REMOTE_ADDR'],瀏覽目前頁面的使用者的 IP 位址。
$_SERVER['REMOTE_HOST'],瀏覽目前頁面的使用者的主機名稱。 DNS 反向解析不依賴使用者的
REMOTE_ADDR
。$_SERVER['REMOTE_PORT'],用戶機器上連接到 Web 伺服器所使用的連接埠號碼。
$_SERVER['SCRIPT_FILENAME'],目前執行腳本的絕對路徑。
$_SERVER['SERVER_ADMIN'],該值指明了
Apache
伺服器設定檔中的SERVER_ADMIN
參數。如果腳本運行在一個虛擬主機上,則該值是該虛擬主機的值。$_SERVER['SERVER_PORT'],Web 伺服器使用的連接埠。預設值為 "80"。如果使用 SSL 安全連接,則這個值為使用者設定的 HTTP 連接埠。
$_SERVER['SERVER_SIGNATURE'],包含了伺服器版本和虛擬主機名稱的字串。
$_SERVER['PATH_TRANSLATED'],目前腳本所在檔案系統(非文件根目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。
$_SERVER['SCRIPT_NAME'],包含目前腳本的路徑。這在頁面需要指向自己時非常有用。
__FILE__
常數包含目前腳本(例如包含檔案)的完整路徑和檔案名稱。$_SERVER['SCRIPT_URI'],URI 用來指定要存取的頁面。例如 "
/index.html
"。
就說到這裡了,有其他想知道的,可以點選這個喔。 → →php影片教學
#以上是教你玩$_SERVER的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本文比較了酸和基本數據庫模型,詳細介紹了它們的特徵和適當的用例。酸優先確定數據完整性和一致性,適合財務和電子商務應用程序,而基礎則側重於可用性和

本文討論了確保PHP文件上傳的確保,以防止諸如代碼注入之類的漏洞。它專注於文件類型驗證,安全存儲和錯誤處理以增強應用程序安全性。

本文討論了在PHP中實施API速率限制的策略,包括諸如令牌桶和漏水桶等算法,以及使用Symfony/Rate-limimiter之類的庫。它還涵蓋監視,動態調整速率限制和手

本文討論了使用password_hash和pyspasswify在PHP中使用密碼的好處。主要論點是,這些功能通過自動鹽,強大的哈希算法和SECH來增強密碼保護

本文討論了OWASP在PHP和緩解策略中的十大漏洞。關鍵問題包括注射,驗證損壞和XSS,並提供用於監視和保護PHP應用程序的推薦工具。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載
最受歡迎的的開源編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版
好用的JavaScript開發工具