一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php獲取當前網(wǎng)址url并替換參數(shù)或網(wǎng)址的方法

一是php獲取當前頁面的網(wǎng)址:
復(fù)制代碼 代碼如下:
//獲得當前的腳本網(wǎng)址
function GetCurUrl()
{
if(!empty($_SERVER["REQUEST_URI"]))
{
$scriptName = $_SERVER["REQUEST_URI"];
$nowurl = $scriptName;
}
else
{
$scriptName = $_SERVER["php_SELF"];
if(empty($_SERVER["QUERY_STRING"]))
{
$nowurl = $scriptName;
}
else
{
$nowurl = $scriptName."?".$_SERVER["QUERY_STRING"];
}
}
return $nowurl;
}

另一個是php替換網(wǎng)址中query部分的某變量的值比如 ,我們要設(shè)$url中的key=321;
其實有幾種情況:
$url='www.sina.com/a.php?key=330′;
或$url='www.sina.com/a.php;
或$url='www.sina.com/a.php?cat=2′;
等等。雖然情況很多,但php處理起來非常簡單,如下:
復(fù)制代碼 代碼如下:
/* 將URL中的某參數(shù)設(shè)為某值*/ //【這一段就挺好啊】
function url_set_value($url,$key,$value)
{
$a=explode('?',$url);
$url_f=$a[0];
$query=$a[1];
parse_str($query,$arr);
$arr[$key]=$value;
return $url_f.'?'.http_build_query($arr);
}

不過我的替換是這樣寫的。。當然也很爛 。。
復(fù)制代碼 代碼如下:
<?php
/**
*使用例程:可用于分頁類或頁面中的替換等
$url = "add_jd.php?pid=4&tb=gm_jd&page=1";
echo( "原始的URL:" . $url );
echo( '<br/>' );
echo( "字符串參數(shù):" . url::replace( $url , "pid=10,page=2") );
echo( '<br/>' );
echo( "數(shù)組型參數(shù):" . url::replace( $url , array('pid'=>10,'page'=>5)) );
//echo( urlReplace( $url , array('pid'=>10,'page'=>5)) );
*/
/**
* url replace
* @param string $url 需要替換的URL字符串,一般為aaa.php?abc=def,也可以帶上路徑,象http://xxx.com/abc/def.php?aa=bb
* @param mixed $options 需要替換的變量,可以是字符串或數(shù)組,如果是字符串,格式為"aa=bb,cc=dd",有多個,用","隔開
* @return string $url 替換后的URL
*/
class url
{
static function replace ( $url , $options)
{
$options = self::optInit( $options );
$Query = parse_url( $url , php_URL_QUERY );
if($Query){
parse_str( $Query , $GET );
if ( $GET ){
//foreach ( $GET as $_k => $_v ){
// //if( array_key_exists( $_k , $options)){
// $GET[$_k] = $options[$_k];
// //}
//}
$GET = array_merge($GET,$options);
}
return str_replace( $Query , http_build_query( $GET ), $url );
}
if( !$Query && $options ){
return $url . "?" . http_build_query($options);
}
return $url;
}
static private function optInit ( $options )
{
if( is_string( $options )){
$optlists = Power::Normalize( $options );
foreach( $optlists as $val){
list($tmpKey,$tmpVal) = Power::Normalize( $val , "=");
$opts[$tmpKey] = $tmpVal;
}
}else{
$opts = $options;
}
//unset( $options );
return $opts;
}
}

雖然考慮了一些東西,但也僅僅是個很一般的解決方法

以下是一些補充資料:
例: 我需要 獲取當前的 的URL 地址
$url_this = "http://".$_SERVER ['HTTP_HOST'].$_SERVER['php_SELF'];
echo $url_this;

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

服務(wù)器變量:$_SERVER
注: 在 php 4.1.0 及以后版本使用。之前的版本,使用 $HTTP_SERVER_VARS。

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

這是一個“superglobal”,或者可以描述為自動全局變量。這只不過意味這它在所有的腳本中都有效。在函數(shù)或方法中您不需要使用 global $_SERVER; 訪問它,就如同使用 $HTTP_SERVER_VARS 一樣。

$HTTP_SERVER_VARS 包含著同樣的信息,但是不是一個自動全局變量。(注意: $HTTP_SERVER_VARS 和 $_SERVER 是不同的變量,php 處理它們的方式不同。)

如果設(shè)置了 register_globals 指令,這些變量也在所有腳本中可用;也就是,分離了 $_SERVER 和 $HTTP_SERVER_VARS 數(shù)組。相關(guān)信息,請參閱安全的相關(guān)章節(jié) 使用 Register Globals。這些單獨的全局變量不是自動全局變量。

您或許會發(fā)現(xiàn)下面列出的某些 $_SERVER 元素并不可用。注意,如果以命令行方式運行 php,下面列出的元素幾乎沒有有效的(或是沒有任何實際意義的)。


php_SELF”
當前正在執(zhí)行腳本的文件名,與 document root相關(guān)。舉例來說,在URL地址為 http://example.com/test.php/foo.bar 的腳本中使用 $_SERVER['php_SELF'] 將會得到 /test.php/foo.bar 這個結(jié)果。

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

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

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

“GATEWAY_INTERFACE”
服務(wù)器使用的 CGI 規(guī)范的版本。例如,“CGI/1.1”。

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

'SERVER_SOFTWARE'
服務(wù)器標識的字串,在響應(yīng)請求時的頭部中給出。

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

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

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

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

“HTTP_ACCEPT”
當前請求的 Accept: 頭部的內(nèi)容。

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

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

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

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

“HTTP_HOST”
當前請求的 Host: 頭部的內(nèi)容。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

php技術(shù)php獲取當前網(wǎng)址url并替換參數(shù)或網(wǎng)址的方法,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产成人精品亚洲午夜麻豆 | 中文字幕在线一区二区在线 | 欧美性猛交xx免费看 | www.黄色免费 | 国产成人精品实拍在线 | 欧美五级在线观看视频播放 | 亚洲综合一区二区不卡 | 91免费永久在线地址 | 亚洲伊人色一综合网 | 韩国一级毛片视频免费观看 | 亚亚洲乱码一二三四区 | 国产午夜精品福利久久 | 毛片色毛片18毛片美女 | 国产情侣真实露脸在线 | 国产一区二区精品在线观看 | 亚欧精品一区二区三区四区 | 悠悠影院欧美日韩国产 | 狠狠大日本亚洲香蕉亚洲 | 国产精品成人亚洲 | 色吧综合网 | 国产女主播福利在线 | 色婷婷av777 色婷婷成人 | 四虎影永久在线观看网址 | 午夜欧美性欧美 | 免费国产成人综合 | 免费国产人做人视频在线观看 | 三级色网站| 国产亚洲婷婷香蕉久久精品 | 色综合天天色综合 | 亚洲一区二区免费在线观看 | 亚洲国产成人资源在线软件 | 亚洲视频一区二区 | 国内一区二区三区精品视频 | 亚洲乱码在线视频 | 久久福利一区 | 干色网 | 韩国美女一级片 | 国产激情视频在线观看 | 欧美视频精品 | 天天干天天干天天干 | 成人美女黄网站色大色费 |