php獲取瀏覽器插件信息,php獲取瀏覽器插件信息失敗

本文目錄一覽:

php 如何獲取伺服器的信息

伺服器變數 $_SERVER 詳解:

1、$_SESSION[‘PHP_SELF’] — 獲取當前正在執行腳本的文件名

2、$_SERVER[‘SERVER_PROTOCOL’] — 請求頁面時通信協議的名稱和版本。例如,「HTTP/1.0」。

3、$_SERVER[‘REQUEST_TIME’] — 請求開始時的時間戳。從 PHP 5.1.0 起有效。和time函數效果一樣。

4、$_SERVER[‘argv’] — 傳遞給該腳本的參數。我試了下,get方法可以得到$_SERVER[‘argv’][0];post方法無法給他賦值。

5、$_SERVER[‘SERVER_NAME’] — 返回當前主機名。

6、$_SERVER[‘SERVER_SOFTWARE’] — 伺服器標識的字串,在響應請求時的頭信息中給出。 如Microsoft-IIS/6.0

7、$_SERVER[‘REQUEST_METHOD’] — 訪問頁面時的請求方法。例如:「GET」、「HEAD」,「POST」,「PUT」。

8、$_SERVER[‘QUERY_STRING’] — 查詢(query)的字元串(URL 中第一個問號 ? 之後的內容)。

9、$_SERVER[‘DOCUMENT_ROOT’] — 當前運行腳本所在的文檔根目錄。在伺服器配置文件中定義。 如E:\server

10、$_SERVER[‘HTTP_ACCEPT’] — 當前請求的 Accept: 頭信息的內容。

11、$_SERVER[‘HTTP_ACCEPT_CHARSET’] — 當前請求的 Accept-Charset: 頭信息的內容。例如:「iso-8859-1,*,utf-8」。

12、$_SERVER[‘HTTP_ACCEPT_ENCODING’] — 當前請求的 Accept-Encoding: 頭信息的內容。例如:「gzip」。

13、$_SERVER[‘HTTP_ACCEPT_LANGUAGE’] — 當前請求的 Accept-Language: 頭信息的內容。例如:「en」。

14、$_SERVER[‘HTTP_CONNECTION’] — 當前請求的 Connection: 頭信息的內容。例如:「Keep-Alive」。

15、$_SERVER[‘HTTP_HOST’] — 當前請求的 Host: 頭信息的內容。

16、$_SERVER[‘HTTP_REFERER’] — 鏈接到當前頁面的前一頁面的 URL 地址。

17、$_SERVER[‘HTTP_USER_AGENT’] — 返回用戶使用的瀏覽器信息。也可以使用 get_browser() 得到此信息。

18、$_SERVER[‘HTTPS’] — 如果通過https訪問,則被設為一個非空的值,否則返回off.

19、$_SERVER[‘REMOTE_ADDR’] — 正在瀏覽當前頁面用戶的 IP 地址。

20、$_SERVER[‘REMOTE_HOST’] — 正在瀏覽當前頁面用戶的主機名。反向域名解析基於該用戶的 REMOTE_ADDR。如本地測試返回127.0.0.1

21、$_SERVER[‘REMOTE_PORT’] — 用戶連接到伺服器時所使用的埠。我在本機測試沒通過,不知道什麼原因。

22、$_SERVER[‘SCRIPT_FILENAME’] — 當前執行腳本的絕對路徑名。如返回E:\server\index.php

23、$_SERVER[‘SERVER_ADMIN’] — 該值指明了 Apache 伺服器配置文件中的 SERVER_ADMIN 參數。如果腳本運行在一個虛擬主機上,則該值是那個虛擬主機的值

24、$_SERVER[‘SERVER_PORT’] — 伺服器所使用的埠。默認為「80」。如果使用 SSL 安全連接,則這個值為用戶設置的 HTTP 埠。

25、$_SERVER[‘SERVER_SIGNATURE’] — 包含伺服器版本和虛擬主機名的字元串。

26、$_SERVER[‘PATH_TRANSLATED’] — 當前腳本所在文件系統(不是文檔根目錄)的基本路徑。這是在伺服器進行虛擬到真實路徑的映像後的結果。 Apache 2 用 戶可以使用 httpd.conf 中的 AcceptPathInfo On 來定義 PATH_INFO。

27、$_SERVER[‘SCRIPT_NAME’] — 包含當前腳本的路徑。這在頁面需要指向自己時非常有用。__FILE__ 包含當前文件的絕對路徑和文件名(例如包含文件)。

28、$_SERVER[‘REQUEST_URI’] — 訪問此頁面所需的 URI。例如,「/index.html」。

29、$_SERVER[‘PHP_AUTH_DIGEST’] — 當作為 Apache 模塊運行時,進行 HTTP Digest 認證的過程中,此變數被設置成客戶端發送的「Authorization」HTTP 頭內容(以便作進一步的認證操作)。

30、$_SERVER[‘PHP_AUTH_USER’]– 當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是用戶輸入的用戶名。

31、$_SERVER[‘PHP_AUTH_PW’] — 當 PHP 運行在 Apache 或 IIS(PHP 5 是 ISAPI)模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是用戶輸入的密碼。

32、$_SERVER[‘AUTH_TYPE’]–當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變數便是認證的類型。

php 可以獲取用戶瀏覽器的緩存內容嗎

恐怕不行,php唯一能直接獲取到的用戶信息就是用戶發送請求的header裡面的東西,還有硬碟上的cookies,由於瀏覽器的安全策略,要訪問用戶硬碟其他位置,即使配合html和js也要用戶主動通過表單選擇提交才行。除非客戶端安裝了activex之類的瀏覽器插件,用控制項來訪問本地硬碟,並和服務端通信,但前提是用戶信任你,並安裝你提供的插件才行

我用PHP $_SERVER[‘HTTP_USER_AGENT’] 獲取到的客戶瀏覽器信息只有 「Mozilla/4.0」 這是什麼瀏覽器?

簡單來說,瀏覽分為兩部分構成:shell+內核。其中shell的種類相對比較多,內核則比較少。shell是指瀏覽器的外殼,例如菜單工具欄目等,主要是提供給用戶界面操作,參數設置等等,它是調用內核來實現各種功能的,內核才是瀏覽器的核心。內核是基於標記語言顯示內容的程序或模塊,也有一些瀏覽並不區分內核和外殼,從Mozilla將Gecko獨立出來以後,才有了外殼和內核的明確劃分。目前主流瀏覽有:IE6,IE8,Mozilla FireFox,Opera,Safari,chrome,Netscape等。

瀏覽器內核又可以分為兩部分:渲染引擎和JS引擎。它負責取得網頁的內容(HTML,XML,圖像等等)、訊息整理(例如加入CSS等),然後會輸出至顯示器或者印表機。瀏覽器內核的不同對於網頁的語法解釋會有不同,所以渲染的效果也不同,所有網頁瀏覽器,電子郵件客房端,以及其它需要編輯,顯示網路內容的應用都需要內核,JS引擎則是解析javascript語言,執行javascript語言來實現網頁的動態效果。最開始渲染引擎和JS引擎沒有區分很明確,後來JS引擎越來越獨立,內核引擎就傾向於只指渲染引擎,有一個網頁標準計劃小組製作了一個ACID來測試引擎的兼容性和性能,內核的種類很多,如加上沒什麼人使用的非商業的免費內核,可能會有十多種,但是常見的瀏覽器內核可以分為四種:Trient\Gecko\Presto\Webkit.

Trident 又稱MSHTML,是微軟開的渲染引擎(包含了javascript引擎JScript),它已深入了Window系統的骨髓,例如:Window Player,Window explore,OutLook express等都使用了,目前很多瀏覽都使用這個引擎,如IE,Maxthon(最新版本使用Webkit).

Gecko:是使用C++開發的,Open Source的渲染引擎,包括了SpiderMonkey(Rhino)。主要的使用者有Firefox。

Webkit:是蘋果公司基於KHTML開發的,包括Webcore和JavaScriptCore(SquirrelFish,V8)兩個引擎。主要使用者有Safari,chrome.

Presto:Opera software公司開發的,用於Opera引擎渲染,Macromedia Dreamweaver (MX版本及以上)和Adobe Creative Suite 2也使用了Presto的內核。

Trident內核:IE,MaxThon,TT,The World,360,搜狗瀏覽器等

Gecko內核:Netscape6及以上版本,FF,MozillaSuite/SeaMonkey等

Presto內核:Opera7及以上

Webkit內核:Safari,Chrome等

1,Trident內核和W3C標準脫節。

2,Trident內核的大量Bug等安全問題沒有得到解決,加上一些專家學者公開自己認為IE瀏覽器不安全的觀點,使很多用戶開始轉向其他瀏覽器,FF,Opera就是這時期興起的。

Gecko:這是Firefox 和 Flock 所採用內核,這個內核的優點就是功能強大、豐富,可以支持很多複雜網頁效果和瀏覽器擴展介面,但是代價是也顯而易見就是要消耗很多的資源,比如內存。

Presto:Opera 採用的是 Presto內核,Presto內核被稱為公認的瀏覽網頁速度最快的內核,這得益於它在開發時的天生優勢,在處理JS腳本等腳本語言時,會比其他的內核快3倍左右,缺點就是為了達到很快的速度而丟掉了一部分網頁兼容性。

如何用php得到當前瀏覽器地址欄中文件的擴展名答案

$filename = $_SERVER[‘SCRIPT_FILENAME’]; //獲得當前執行腳本的絕對路徑

$array = explode(‘.’,$filename); //以「.」分割字元串,獲得數組

$file_ext = pop($array); //獲得該數組的最後一個key,也就是文件名的後綴

php 怎麼獲取瀏覽器的類型?

獲取客戶端瀏覽器、IP地址操作系統類型等的方法(PHP)

=========================

獲取客戶端信息(瀏覽器、IP、OS)

?php

/*

作用:取得客戶端信息

參數:

返回:指定的資料

使用:

$code = new clientGetObj;

1、瀏覽器:$str = $code-getBrowse();

2、IP地址:$str = $code-getIP();

4、操作系統:$str = $code-getOS();

*/

class clientGetObj

{

function getBrowse()

{

global $_SERVER;

$Agent = $_SERVER[‘HTTP_USER_AGENT’];

$browser = ”;

$browserver = ”;

$Browser = array(‘Lynx’, ‘MOSAIC’, ‘AOL’, ‘Opera’, ‘JAVA’, ‘MacWeb’, ‘WebExplorer’, ‘OmniWeb’);

for($i = 0; $i = 7; $i ++){

if(strpos($Agent, $Browsers[$i])){

$browser = $Browsers[$i];

$browserver = ”;

}

}

if(ereg(‘Mozilla’, $Agent) !ereg(‘MSIE’, $Agent)){

$temp = explode(‘(‘, $Agent);

$Part = $temp[0];

$temp = explode(‘/’, $Part);

$browserver = $temp[1];

$temp = explode(‘ ‘, $browserver);

$browserver = $temp[0];

$browserver = preg_replace(‘/([d.]+)/’, ‘\1’, $browserver);

$browserver = $browserver;

$browser = ‘Netscape Navigator’;

}

if(ereg(‘Mozilla’, $Agent) ereg(‘Opera’, $Agent)) {

$temp = explode(‘(‘, $Agent);

$Part = $temp[1];

$temp = explode(‘)’, $Part);

$browserver = $temp[1];

$temp = explode(‘ ‘, $browserver);

$browserver = $temp[2];

$browserver = preg_replace(‘/([d.]+)/’, ‘\1’, $browserver);

$browserver = $browserver;

$browser = ‘Opera’;

}

if(ereg(‘Mozilla’, $Agent) ereg(‘MSIE’, $Agent)){

$temp = explode(‘(‘, $Agent);

$Part = $temp[1];

$temp = explode(‘;’, $Part);

$Part = $temp[1];

$temp = explode(‘ ‘, $Part);

$browserver = $temp[2];

$browserver = preg_replace(‘/([d.]+)/’,’\1′,$browserver);

$browserver = $browserver;

$browser = ‘Internet Explorer’;

}

if($browser != ”){

$browseinfo = $browser.’ ‘.$browserver;

} else {

$browseinfo = false;

}

return $browseinfo;

}

function getIP ()

{

global $_SERVER;

if (getenv(‘HTTP_CLIENT_IP’)) {

$ip = getenv(‘HTTP_CLIENT_IP’);

} else if (getenv(‘HTTP_X_FORWARDED_FOR’)) {

$ip = getenv(‘HTTP_X_FORWARDED_FOR’);

} else if (getenv(‘REMOTE_ADDR’)) {

$ip = getenv(‘REMOTE_ADDR’);

} else {

$ip = $_SERVER[‘REMOTE_ADDR’];

}

return $ip;

}

function getOS ()

{

global $_SERVER;

$agent = $_SERVER[‘HTTP_USER_AGENT’];

$os = false;

if (eregi(‘win’, $agent) strpos($agent, ’95’)){

$os = ‘Windows 95’;

}

else if (eregi(‘win 9x’, $agent) strpos($agent, ‘4.90’)){

$os = ‘Windows ME’;

}

else if (eregi(‘win’, $agent) ereg(’98’, $agent)){

$os = ‘Windows 98’;

}

else if (eregi(‘win’, $agent) eregi(‘nt 5.1’, $agent)){

$os = ‘Windows XP’;

}

else if (eregi(‘win’, $agent) eregi(‘nt 5’, $agent)){

$os = ‘Windows 2000’;

}

else if (eregi(‘win’, $agent) eregi(‘nt’, $agent)){

$os = ‘Windows NT’;

}

else if (eregi(‘win’, $agent) ereg(’32’, $agent)){

$os = ‘Windows 32’;

}

else if (eregi(‘linux’, $agent)){

$os = ‘Linux’;

}

else if (eregi(‘unix’, $agent)){

$os = ‘Unix’;

}

else if (eregi(‘sun’, $agent) eregi(‘os’, $agent)){

$os = ‘SunOS’;

}

else if (eregi(‘ibm’, $agent) eregi(‘os’, $agent)){

$os = ‘IBM OS/2’;

}

else if (eregi(‘Mac’, $agent) eregi(‘PC’, $agent)){

$os = ‘Macintosh’;

}

else if (eregi(‘PowerPC’, $agent)){

$os = ‘PowerPC’;

}

else if (eregi(‘AIX’, $agent)){

$os = ‘AIX’;

}

else if (eregi(‘HPUX’, $agent)){

$os = ‘HPUX’;

}

else if (eregi(‘NetBSD’, $agent)){

$os = ‘NetBSD’;

}

else if (eregi(‘BSD’, $agent)){

$os = ‘BSD’;

}

else if (ereg(‘OSF1’, $agent)){

$os = ‘OSF1’;

}

else if (ereg(‘IRIX’, $agent)){

$os = ‘IRIX’;

}

else if (eregi(‘FreeBSD’, $agent)){

$os = ‘FreeBSD’;

}

else if (eregi(‘teleport’, $agent)){

$os = ‘teleport’;

}

else if (eregi(‘flashget’, $agent)){

$os = ‘flashget’;

}

else if (eregi(‘webzip’, $agent)){

$os = ‘webzip’;

}

else if (eregi(‘offline’, $agent)){

$os = ‘offline’;

}

else {

$os = ‘Unknown’;

}

return $os;

}

}

?

獲取IP地址

說明:使用 Request.ServerVariables(“REMOTE_ADDR”) 來取得客戶端的 IP 地址,但如果客戶端是使用代理伺服器來訪問,那取到的就是代理伺服器的 IP 地址,而不是真正的客戶端 IP 地址。要想透過代理伺服器取得客戶端的真實IP 地址,就要使用Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 來讀取。不過要注意的事,並不是每個代理伺服器都能用 Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 來讀取客戶端的真實 IP,有些用此方法讀取到的仍然是代理伺服器的 IP。

還有一點需要注意的是:如果客戶端沒有通過代理伺服器來訪問,那麼用 Request.ServerVariables(“HTTP_X_FORWARDED_FOR”) 取到的值將是空的。因此,如果要在程序中使用此方法,可以這樣處理:

……

userip = Request.ServerVariables(“HTTP_X_FORWARDED_FOR”)

If userip = “” Then userip = Request.ServerVariables(“REMOTE_ADDR”)

……

即:如果客戶端通過代理伺服器,則取 HTTP_X_FORWARDED_FOR 的值,如果沒通過代理伺服器,就取 REMOTE_ADDR 的值。

方法一:

function real_ip($type)

{

if ($_SERVER[“HTTP_X_FORWARDED_FOR”])

{

if ($_SERVER[“HTTP_CLIENT_IP”])

{

$proxy = $_SERVER[“HTTP_CLIENT_IP”];

}

else

{

$proxy = $_SERVER[“REMOTE_ADDR”];

}

$ip = $_SERVER[“HTTP_X_FORWARDED_FOR”];

}

else

{

if ($_SERVER[“HTTP_CLIENT_IP”])

{

$ip = $_SERVER[“HTTP_CLIENT_IP”];

}

else

{

$ip = $_SERVER[“REMOTE_ADDR”];

}

}

if($type==’ip’)return $ip;

if($type==’proxy’)return $proxy;

}

方法二:

?

function iptype1 () {

if (getenv(“HTTP_CLIENT_IP”)) {

?return getenv(“HTTP_CLIENT_IP”);

}

else {

?return “none”;

}

}

function iptype2 () {

if (getenv(“HTTP_X_FORWARDED_FOR”)) {

?return getenv(“HTTP_X_FORWARDED_FOR”);

}

else {

?return “none”;

}

}

function iptype3 () {

if (getenv(“REMOTE_ADDR”)) {

?return getenv(“REMOTE_ADDR”);

}

else {

?return “none”;

}

}

function ip() {

$ip1 = iptype1();

$ip2 = iptype2();

$ip3 = iptype3();

if (isset($ip1) $ip1 != “none” $ip1 != “unknown”) {

?return $ip1;

}

elseif (isset($ip2) $ip2 != “none” $ip2 != “unknown”) {

?return $ip2;

}

elseif (isset($ip3) $ip3 != “none” $ip3 != “unknown”) {

?return $ip3;

}?

else {

return “none”;

}

}

Echo ip();

?

方法三:

01 : function ipCheck() {

02 : if (getenv( ‘HTTP_CLIENT_IP’ )) {

03 : $ip = getenv( ‘HTTP_CLIENT_IP’ );

04 : }

05 : elseif (getenv( ‘HTTP_X_FORWARDED_FOR’ )) {

06 : $ip = getenv( ‘HTTP_X_FORWARDED_FOR’ );

07 : }

08 : elseif (getenv( ‘HTTP_X_FORWARDED’ )) {

09 : $ip = getenv( ‘HTTP_X_FORWARDED’ );

10 : }

11 : elseif (getenv( ‘HTTP_FORWARDED_FOR’ )) {

12 : $ip = getenv( ‘HTTP_FORWARDED_FOR’ );

13 : }

14 : elseif (getenv( ‘HTTP_FORWARDED’ )) {

15 : $ip = getenv( ‘HTTP_FORWARDED’ );

16 : }

17 : else {

18 : $ip = $_SERVER[ ‘REMOTE_ADDR’ ];

19 : }

20 : return $ip;

21 : }

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/300222.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-29 12:51
下一篇 2024-12-29 12:51

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • PHP怎麼接幣

    想要在自己的網站或應用中接受比特幣等加密貨幣的支付,就需要對該加密貨幣擁有一定的了解,並使用對應的API進行開發。本文將從多個方面詳細闡述如何使用PHP接受加密貨幣的支付。 一、環…

    編程 2025-04-29
  • Java 監控介面返回信息報錯信息怎麼處理

    本文將從多個方面對 Java 監控介面返回信息報錯信息的處理方法進行詳細的闡述,其中包括如何捕獲異常、如何使用日誌輸出錯誤信息、以及如何通過異常處理機制解決報錯問題等等。以下是詳細…

    編程 2025-04-29
  • 使用Python爬蟲獲取電影信息的實現方法

    本文將介紹如何使用Python編寫爬蟲程序,來獲取和處理電影數據。需要了解基本的Python編程語言知識,並使用BeautifulSoup庫和Requests庫進行爬取。 一、準備…

    編程 2025-04-28
  • 使用PHP foreach遍歷有相同屬性的值

    本篇文章將介紹如何使用PHP foreach遍歷具有相同屬性的值,並給出相應的代碼示例。 一、基礎概念 在講解如何使用PHP foreach遍歷有相同屬性的值之前,我們需要先了解幾…

    編程 2025-04-28
  • Python爬取網頁信息

    本文將從多個方面對Python爬取網頁信息做詳細的闡述。 一、爬蟲介紹 爬蟲是一種自動化程序,可以模擬人對網頁進行訪問獲取信息的行為。通過編寫代碼,我們可以指定要獲取的信息,將其從…

    編程 2025-04-28
  • 如何使用Python執行Shell命令並獲取執行過程信息

    本文將介紹如何使用Python執行Shell命令並獲取執行過程信息。我們將從以下幾個方面進行闡述: 一、執行Shell命令 Python內置的subprocess模塊可以方便地執行…

    編程 2025-04-28
  • Python實現身份信息模擬生成與查驗

    本文將從以下幾個方面對Python實現身份信息模擬生成與查驗進行詳細闡述: 一、身份信息生成 身份信息生成是指通過代碼生成符合身份信息規範的虛假數據。Python中,我們可以使用f…

    編程 2025-04-27
  • PHP獲取301跳轉後的地址

    本文將為大家介紹如何使用PHP獲取301跳轉後的地址。301重定向是什麼呢?當我們訪問一個網頁A,但是它已經被遷移到了另一個地址B,此時若伺服器端做了301重定向,那麼你的瀏覽器在…

    編程 2025-04-27
  • Dapper使用getschema獲取表信息

    本文旨在介紹Dapper中使用getschema獲取表信息的方法和注意事項。 一、獲取某張表的所有列信息 使用Dapper獲取某張表信息,可以使用 `IDbConnection.G…

    編程 2025-04-27

發表回復

登錄後才能評論