php獲取當(dāng)前頁(yè)面完整URL地址
使用PHP編寫(xiě)程序的時(shí)候,我們常常想要獲取當(dāng)前頁(yè)面的URL。下面提供一個(gè)用于獲取當(dāng)前頁(yè)面URL的函數(shù)以及使用方法:
示例一:
<?php
// 說(shuō)明:獲取完整URL
function curPageURL()
{
$pageURL = 'http';
if ($_SERVER["HTTPS"] == "on")
{
$pageURL .= "s";
}
$pageURL .= "://";
if ($_SERVER["SERVER_PORT"] != "80")
{
$pageURL .= $_SERVER["SERVER_NAME"] . ":" . $_SERVER["SERVER_PORT"] . $_SERVER["REQUEST_URI"];
}
else
{
$pageURL .= $_SERVER["SERVER_NAME"] . $_SERVER["REQUEST_URI"];
}
return $pageURL;
}
?>
定義該函數(shù)之后就可以直接調(diào)用了:
<?php echo curPageURL(); ?>
上面的函數(shù)可以獲取當(dāng)前頁(yè)面完整的URL,即你在瀏覽器地址欄看到的內(nèi)容。但是,有時(shí)候我們不想要URL中的參數(shù)( ? 號(hào)后面的內(nèi)容),如:http://www.ludou.org/hello.html?u=123,只想獲取http://www.ludou.org/hello.html,你可以將以上函數(shù)按示例二修改。
示例二:
<?php
// 說(shuō)明:獲取無(wú)參數(shù)URL
function curPageURL()
{
$pageURL = 'http';
if ($_SERVER["HTTPS"] == "on")
{
$pageURL .= "s";
}
$pageURL .= "://";
$this_page = $_SERVER["REQUEST_URI"];
// 只取 ? 前面的內(nèi)容
if (strpos($this_page, "?") !== false)
{
$this_pages = explode("?", $this_page);
$this_page = reset($this_pages);
}
if ($_SERVER["SERVER_PORT"] != "80")
{
$pageURL .= $_SERVER["SERVER_NAME"] . ":" . $_SERVER["SERVER_PORT"] . $this_page;
}
else
{
$pageURL .= $_SERVER["SERVER_NAME"] . $this_page;
}
return $pageURL;
}
?>
當(dāng)然也可以采用 $_SERVER['PHP_SELF'] (該變量不返回URL中的參數(shù)),
示例三:
<?php
// 說(shuō)明:獲取無(wú)參數(shù)URL
function curPageURL()
{
$pageURL = 'http';
if ($_SERVER["HTTPS"] == "on")
{
$pageURL .= "s";
}
$pageURL .= "://";
if ($_SERVER["SERVER_PORT"] != "80")
{
$pageURL .= $_SERVER["SERVER_NAME"].":" . $_SERVER["SERVER_PORT"] . $_SERVER['PHP_SELF'];
}
else
{
$pageURL .= $_SERVER["SERVER_NAME"] . $_SERVER['PHP_SELF'];
}
return $pageURL;
}
?>
另外,$_SERVER['REQUEST_URI'] 和 $_SERVER['REQUEST_URL'] 是有稍微區(qū)別的:
$_SERVER["REQUEST_URI"] 返回完整的路徑,包含參數(shù) ( /directory/file.ext?query=string )
$_SERVER['REQUEST_URL'] 只返回文件路徑,不包括參數(shù),( /directory/file.ext ),和 $_SERVER['PHP_SELF'] 差不多,只不過(guò)在有些服務(wù)器上$_SERVER['REQUEST_URL']不可用!
注意:URL使用rewrite規(guī)則的時(shí)候,$_SERVER['PHP_SELF'] 和 $_SERVER["REQUEST_URL"] 可能不會(huì)返回你想要的東西
最后提醒一點(diǎn),$_SERVER["REQUEST_URI"] 只有 apache 才支持,想要獲取$_SERVER['REQUEST_URI'] 值,可以使用以下方案:
<?php
// 說(shuō)明:獲取 _SERVER['REQUEST_URI'] 值的通用解決方案
function request_uri()
{
if (isset($_SERVER['REQUEST_URI']))
{
$uri = $_SERVER['REQUEST_URI'];
}
else
{
if (isset($_SERVER['argv']))
{
$uri = $_SERVER['PHP_SELF'] .'?'. $_SERVER['argv'][0];
}
else
{
$uri = $_SERVER['PHP_SELF'] .'?'. $_SERVER['QUERY_STRING'];
}
}
return $uri;
}
?>
再為大家分享兩種解決方法:
第一種方法:
<?php
/**
* 獲取當(dāng)前頁(yè)面完整URL地址
*/
function get_url() {
$sys_protocal = isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == '443' ? 'https://' : 'http://';
$php_self = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME'];
$path_info = isset($_SERVER['PATH_INFO']) ? $_SERVER['PATH_INFO'] : '';
$relate_url = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : $php_self.(isset($_SERVER['QUERY_STRING']) ? '?'.$_SERVER['QUERY_STRING'] : $path_info);
return $sys_protocal.(isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '').$relate_url;
}
echo get_url();
?>
第二種方法:
- javascript實(shí)現(xiàn)
top.location.href 頂級(jí)窗口的地址 this.location.href 當(dāng)前窗口的地址
- PHP實(shí)現(xiàn)
#測(cè)試網(wǎng)址: http://localhost/blog/testurl.php?id=5 //獲取域名或主機(jī)地址 echo $_SERVER['HTTP_HOST']."<br>"; #localhost //獲取網(wǎng)頁(yè)地址 echo $_SERVER['PHP_SELF']."<br>"; #/blog/testurl.php //獲取網(wǎng)址參數(shù) echo $_SERVER["QUERY_STRING"]."<br>"; #id=5 //獲取用戶(hù)代理 echo $_SERVER['HTTP_REFERER']."<br>"; //獲取完整的url echo 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI']; echo 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING']; #http://localhost/blog/testurl.php?id=5 //包含端口號(hào)的完整url echo 'http://'.$_SERVER['SERVER_NAME'].':'.$_SERVER["SERVER_PORT"].$_SERVER["REQUEST_URI"]; #http://localhost:80/blog/testurl.php?id=5 //只取路徑 $url='http://'.$_SERVER['SERVER_NAME'].$_SERVER["REQUEST_URI"]; echo dirname($url); #http://localhost/blog
希望本文所述對(duì)大家學(xué)習(xí)php程序設(shè)計(jì)有所幫助。
相關(guān)文章
一家之言的經(jīng)驗(yàn)之談php+mysql扎實(shí)個(gè)人基本功
在學(xué)習(xí)php的過(guò)程中,我們開(kāi)始就需要注意的問(wèn)題2008-03-03
PHP+SQL 注入攻擊的技術(shù)實(shí)現(xiàn)以及預(yù)防辦法
最近在折騰 PHP + MYSQL 的編程。了解了一些 PHP SQL 注入攻擊的知識(shí),于是寫(xiě)了這篇文章.2010-12-12
PHP進(jìn)階學(xué)習(xí)之命名空間基本用法分析
這篇文章主要介紹了PHP進(jìn)階學(xué)習(xí)之命名空間基本用法,簡(jiǎn)單分析了php命名空間的基本概念、功能并結(jié)合實(shí)例形式描述了命名空間的用法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-06-06
如何在舊的PHP系統(tǒng)中使用PHP 5.3之后的庫(kù)
這篇文章主要介紹了如何在舊的PHP系統(tǒng)中使用PHP 5.3之后的庫(kù),需要的朋友可以參考下2015-12-12
php獲取Google機(jī)器人訪(fǎng)問(wèn)足跡的方法
這篇文章主要介紹了php獲取Google機(jī)器人訪(fǎng)問(wèn)足跡的方法,涉及正則匹配與預(yù)定義服務(wù)器變量的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04

