程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP URL地址獲取函數代碼(端口等) 推薦

PHP URL地址獲取函數代碼(端口等) 推薦

編輯:關於PHP編程

php 獲得當前的腳本網址(只有路徑)
復制代碼 代碼如下:
function GetCurUrl()
{
if(!empty($_SERVER["REQUEST_URI"]))
{
$scrtName = $_SERVER["REQUEST_URI"];
$nowurl = $scrtName;
}
else
{
$scrtName = $_SERVER["PHP_SELF"];
if(empty($_SERVER["QUERY_STRING"]))
{
$nowurl = $scrtName;
}
else
{
$nowurl = $scrtName."?".$_SERVER["QUERY_STRING"];
}
}
return $nowurl;
}
//實例調用方法
//echo GEtCurUrl();

php 獲取url地址不包含路徑(域名或ip地址)
復制代碼 代碼如下:
function getServerName()
{
$ServerName = strtolower($_SERVER['SERVER_NAME']?$_SERVER['SERVER_NAME']:$_SERVER['HTTP_HOST']);
if( strpos($ServerName,'http://') )
{
return str_replace('http://','',$ServerName);
}
return $ServerName;
}
//實例調用方法
echo getServerName();

php 獲取url地址包含端口路徑
復制代碼 代碼如下:
echo 'http://'.$_SERVER['SERVER_NAME'].':'.$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"];


主要是獲取到地址欄的一些信息,域名,端口參數等
復制代碼 代碼如下:
<?php
//獲取域名或主機地址
echo $_SERVER['HTTP_HOST']."<br>";
//獲取網頁地址
echo $_SERVER['PHP_SELF']."<br>";
//獲取網址參數
echo $_SERVER["QUERY_STRING"]."<br>";
//來源網頁的詳細地址
echo $_SERVER['HTTP_REFERER']."<br>";
?>


例: 我需要 獲取當前的 的URL 地址
$url_this = "http://".$_SERVER ['HTTP_HOST'].$_SERVER['PHP_SELF'];
echo $url_this;


則顯示 : http://localhost/lu.php


服務器變量:$_SERVER
注: 在 PHP 4.1.0 及以後版本使用。之前的版本,使用 $HTTP_SERVER_VARS。

$_SERVER 是一個包含諸如頭部(headers)、路徑(paths)和腳本位置(script locations)的數組。數組的實體由 web 服務器創建。不能保證所有的服務器都能產生所有的信息;服務器可能忽略了一些信息,或者產生了一些未在下面列出的新的信息。這意味著,大量的這些變量在 CGI 1.1 specification 中說明,所以您應該仔細研究它。

這是一個“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地址為 http://example.com/test.php/foo.bar 的腳本中使用 $_SERVER['PHP_SELF'] 將會得到 /test.php/foo.bar 這個結果。

如果 PHP 以命令行方式運行,該變量無效。

“argv”
傳遞給該腳本的參數。當腳本運行在命令行方式時,argv 變量傳遞給程序 C 語言樣式的命令行參數。當調用 GET 方法時,該變量包含請求的數據。

“argc”
包含傳遞給程序的命令行參數的個數(如果運行在命令行模式)。

“GATEWAY_INTERFACE”
服務器使用的 CGI 規范的版本。例如,“CGI/1.1”。

'SERVER_NAME'
當前運行腳本所在服務器主機的名稱。如果該腳本運行在一個虛擬主機上,該名稱是由那個虛擬主機所設置的值決定。

'SERVER_SOFTWARE'
服務器標識的字串,在響應請求時的頭部中給出。

“SERVER_PROTOCOL”
請求頁面時通信協議的名稱和版本。例如,“HTTP/1.0”。

“REQUEST_METHOD”
訪問頁面時的請求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

“QUERY_STRING”
查詢(query)的字符串。

“DOCUMENT_ROOT”
當前運行腳本所在的文檔根目錄。在服務器配置文件中定義。

“HTTP_ACCEPT”
當前請求的 Accept: 頭部的內容。

“HTTP_ACCEPT_CHARSET”
當前請求的 Accept-Charset: 頭部的內容。例如:“iso-8859-1,*,utf-8”。

“HTTP_ACCEPT_ENCODING”
當前請求的 Accept-Encoding: 頭部的內容。例如:“gzip”。

“HTTP_ACCEPT_LANGUAGE”
當前請求的 Accept-Language: 頭部的內容。例如:“en”。

“HTTP_CONNECTION”
當前請求的 Connection: 頭部的內容。例如:“Keep-Alive”。

“HTTP_HOST”
當前請求的 Host: 頭部的內容。

“HTTP_REFERER”
鏈接到當前頁面的前一頁面的 URL 地址。不是所有的用戶代理(浏覽器)都會設置這個變量,而且有的還可以手工修改 HTTP_REFERER。因此,這個變量不總是正確真實的。

“HTTP_USER_AGENT”
當前請求的 User_Agent: 頭部的內容。該字符串表明了訪問該頁面的用戶代理的信息。一個典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。您也可以使用 get_browser() 得到這個信息。

“REMOTE_ADDR”
正在浏覽當前頁面用戶的 IP 地址。

'REMOTE_HOST'
正在浏覽當前頁面用戶的主機名。反向域名解析基於該用戶的 REMOTE_ADDR。

注: 必須配置 Web 服務器來建立此變量。例如 Apache 需要在 httpd.conf 中有 HostnameLookups On。參見 gethostbyaddr()。

“REMOTE_PORT”
用戶連接到服務器時所使用的端口。

“SCRIPT_FILENAME”
當前執行腳本的絕對路徑名。

“SERVER_ADMIN”
該值指明了 Apache 服務器配置文件中的 SERVER_ADMIN 參數。如果腳本運行在一個虛擬主機上,則該值是那個虛擬主機的值。

“SERVER_PORT”
服務器所使用的端口。默認為“80”。如果你使用 SSL 安全連接,則這個值為您所設置的 HTTP 端口。

“SERVER_SIGNATURE”
包含服務器版本和虛擬主機名的字符串。

“PATH_TRANSLATED”
當前腳本所在文件系統(不是文檔根目錄)的基本路徑。這是在服務器進行虛擬到真實路徑的映像後的結果。

“SCRIPT_NAME”
包含當前腳本的路徑。這在頁面需要指向自己時非常有用。

“REQUEST_URI”
訪問此頁面所需的 URI。例如,“/index.html”。

“PHP_AUTH_USER”
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變量便是用戶輸入的用戶名。

“PHP_AUTH_PW”
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變量便是用戶輸入的密碼。

“AUTH_TYPE”
當 PHP 運行在 Apache 模塊方式下,並且正在使用 HTTP 認證功能,這個變量便是認證的類型。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved