問(wèn)題是這樣的,某個(gè)情況下要給:http://jb51.net?a=1
這類url地址追加參數(shù)變?yōu)椋篽ttp://jb51.net?a=1&b=2
但是怎么知道已經(jīng)存在相同參數(shù)名呢,例如有這種情況:http://jb51.net?a=1&a=2
這個(gè)雖然不會(huì)有什么大錯(cuò)誤,但是地址欄這樣看起來(lái)很不好。那怎么辦呢?用正則解決吧(本來(lái)我想用php的字符串處理解決的,但是后來(lái)覺(jué)得要學(xué)一下正則了就用正則做吧)
以下是我用于返回上一頁(yè)的后臺(tái)處理方法
$url = $_SESSION[‘BACKURL’];
if($get!=array())
foreach ($get as $k=>$g){
$url.=’&’.$k.’=’.$g;//先追加所有要追加的參數(shù),不管是否重復(fù)
if(count(explode(“&{$k}=”,$url))>2){//假如以”&a=”這種格式分割目前url字符串發(fā)現(xiàn)有超過(guò)兩個(gè)的分割數(shù)組,即表明該字符串有重復(fù)參數(shù)
$url=preg_replace(“/{$k}=[a-zA-Z0-9]*&/”,”,$url);//正則替換所有”&a=x”為空
}
}
unset($_SESSION[‘BACKURL’]);
$this->alert($msg,$url);
}
簡(jiǎn)單的解釋:
“/{$k}=[a-zA-Z0-9]*&/”假如我們假設(shè)$k=”a”,即”/a=[a-zA-Z0-9]*&/”
不知道有沒(méi)理解錯(cuò),這個(gè)意思其實(shí)是匹配以”a=”開(kāi)頭,緊跟任意數(shù)字字母組合([a-zA-Z0-9]*:意思是任意單個(gè)數(shù)字或者字母字符,可以把*理解為對(duì)前面那個(gè)任意字符的重復(fù),如u*可以理解為:uuuu…..,不限制個(gè)數(shù)的u排列,這里的*可以用{0,}代替),再緊跟”&”。
這是個(gè)很簡(jiǎn)單的例子,但是看網(wǎng)上的關(guān)于正則語(yǔ)法的描述,總感覺(jué)看不明白,不知道是我理解能力問(wèn)題還是寫(xiě)得人說(shuō)得太深?yuàn)W。
另外解釋一下,為什么這樣就可以去除重復(fù),原理很簡(jiǎn)單,http://jb51.net?a=1&a=2被替換”&a=x”格式字符的時(shí)候最后一個(gè)正好不會(huì)被刪除,要知道我們循環(huán)中每次我們都是把新參數(shù)放在最后面的。