您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關(guān)使用php怎么獲取當前頁面的完整URL地址,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
示例一:
<?php // 說明:獲取完整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ù)可以獲取當前頁面完整的URL,即你在瀏覽器地址欄看到的內(nèi)容。但是,有時候我們不想要URL中的參數(shù)( ? 號后面的內(nèi)容),如:http://www.ludou.org/hello.html?u=123,只想獲取http://www.ludou.org/hello.html,你可以將以上函數(shù)按示例二修改。
示例二:
<?php // 說明:獲取無參數(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; } ?>
當然也可以采用 $_SERVER['PHP_SELF'] (該變量不返回URL中的參數(shù)),
示例三:
<?php // 說明:獲取無參數(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'] 差不多,只不過在有些服務(wù)器上$_SERVER['REQUEST_URL']不可用!
注意:URL使用rewrite規(guī)則的時候,$_SERVER['PHP_SELF'] 和 $_SERVER["REQUEST_URL"] 可能不會返回你想要的東西
最后提醒一點,$_SERVER["REQUEST_URI"] 只有 apache 才支持,想要獲取$_SERVER['REQUEST_URI'] 值,可以使用以下方案:
<?php // 說明:獲取 _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 /** * 獲取當前頁面完整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實現(xiàn)
top.location.href 頂級窗口的地址 this.location.href 當前窗口的地址
PHP實現(xiàn)
#測試網(wǎng)址: http://localhost/blog/testurl.php?id=5 //獲取域名或主機地址 echo $_SERVER['HTTP_HOST']."<br>"; #localhost //獲取網(wǎng)頁地址 echo $_SERVER['PHP_SELF']."<br>"; #/blog/testurl.php //獲取網(wǎng)址參數(shù) echo $_SERVER["QUERY_STRING"]."<br>"; #id=5 //獲取用戶代理 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 //包含端口號的完整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
關(guān)于使用php怎么獲取當前頁面的完整URL地址就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。