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