AJAX 請求區分 $_SERVER['HTTP_X_REQUESTED_WITH'] 小解


關於這個內容,很多人都有所了解。但從我搜索的內容來看,他們只是略微看一下,根本不知道里面到底是什么情況。

受到很多模版代碼的影響,大家都以為PHP有這樣一個自定義變量:$_SERVER['HTTP_X_REQUESTED_WITH'], 其實根本不是那么回事。

$_SERVER是一個包含諸如頭信息(header),路徑(path)和腳本位置(script locations)的數組。這是PHP手冊的原話。

有 一些頭信息是系統本身就存在的,且不能更改,比如說HOSTUSER_AGENT等等,注意我們常用到的 是$_SERVER['HTTP_HOST'],$_SERVER['HTTP_USER_AGENT'],這里面都有HTTP前綴,實現上在 header信息里面是沒有HTTP前綴的,信息名稱只是HOST之類的,$_SERVER自動的為他們加上HTTP前綴,一是為了防止與本身的其它信息 相沖突,二是為了表示他們是header頭部的信息。所以$_SERVER中的變量凡是帶有HTTP前綴的均是header信息,沒有的則不是, 如:$_SERVER['QUERY_STRING'],$_SERVER['PHP_SELF']等。

用戶可以創建自定義的header頭部信息,並把這些信息發送給服務器端, 服務器端就會記錄這些header信息,並把他們存儲到$_SERVER變量中,當然實現的變量名稱變成了"HTTP_"連上用戶的變量名稱。比如上面的 判斷ajax請求。實際上是在向服務器發送異步請求之前,向header中加入一條header信息,實際的語句應該是:

HttpRequest 對象.setRequestHeader("X_REQUESTED_WITH", "任意字符串");

服務器端通 過$_SERVER['HTTP_X_REQUESTED_WITH']這個變量是否存在,或具體的值來判斷是否是ajax請求或具體是哪一條ajax請 求。  所以利用這個不但可以驗證請求是否是ajax請求,還可以獲取更多的信息。

同樣我們可以在header中任意設置其它的信息,用於跟服務器端進行數據交流。比 如:

xmlHttpRequest.setRequestHeader("test", "just a test");

那么被請求的服務器頁面中的變量$_SERVER['HTTP_TEST']的值就是"just a test";注意這里面前面的test不固定大小寫。后面的$_SERVER['HTTP_TEST']必須是大寫。

 


 

順便把執行一下如下代碼:

<?php
print_r($_SERVER);
?>

輸出:

Array
(
    [MIBDIRS] => D:/php/xampp/php/extras/mibs
    [MYSQL_HOME] => xamppmysqlin
    [OPENSSL_CONF] => D:/php/xampp/apache/bin/openssl.cnf
    [PHP_PEAR_SYSCONF_DIR] => xamppphp
    [PHPRC] => xamppphp
    [TMP] => xampp	mp
    [HTTP_HOST] => wenjb
    [HTTP_USER_AGENT] => Mozilla/5.0 (Windows NT 5.1; rv:12.0) Gecko/20100101 Firefox/12.0
    [HTTP_ACCEPT] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
    [HTTP_ACCEPT_LANGUAGE] => zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3
    [HTTP_ACCEPT_ENCODING] => gzip, deflate
    [HTTP_CONNECTION] => keep-alive
    [HTTP_CACHE_CONTROL] => max-age=0
    [PATH] => C:WINDOWSsystem32;C:WINDOWS;C:WINDOWSSystem32Wbem;D:Program FilesTortoiseSVNin;D:Program FilesSSH Secure Shell
    [SystemRoot] => C:WINDOWS
    [COMSPEC] => C:WINDOWSsystem32cmd.exe
    [PATHEXT] => .COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH
    [WINDIR] => C:WINDOWS
    [SERVER_SIGNATURE] => <address>Apache/2.2.21 (Win32) mod_ssl/2.2.21 OpenSSL/1.0.0e PHP/5.3.8 mod_perl/2.0.4 Perl/v5.10.1 Server at wenjb Port 80</address>

    [SERVER_SOFTWARE] => Apache/2.2.21 (Win32) mod_ssl/2.2.21 OpenSSL/1.0.0e PHP/5.3.8 mod_perl/2.0.4 Perl/v5.10.1
    [SERVER_NAME] => wenjb
    [SERVER_ADDR] => 10.10.24.170
    [SERVER_PORT] => 80
    [REMOTE_ADDR] => 10.10.24.170
    [DOCUMENT_ROOT] => D:/php/xampp/htdocs
    [SERVER_ADMIN] => postmaster@localhost
    [SCRIPT_FILENAME] => D:/php/xampp/htdocs/cbs/src/ws_cbs/wjbphp.php
    [REMOTE_PORT] => 1675
    [GATEWAY_INTERFACE] => CGI/1.1
    [SERVER_PROTOCOL] => HTTP/1.1
    [REQUEST_METHOD] => GET
    [QUERY_STRING] =>
    [REQUEST_URI] => /cbs/src/ws_cbs/wjbphp.php
    [SCRIPT_NAME] => /cbs/src/ws_cbs/wjbphp.php
    [PHP_SELF] => /cbs/src/ws_cbs/wjbphp.php
    [REQUEST_TIME] => 1336816781
)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM