网络编程 
首页 > 网络编程 > 浏览文章

学php正则!超基础简单例子

(编辑:jimmy 日期: 2024/11/16 浏览:3 次 )
问题是这样的,某个情况下要给:http://jb51.net?a=1

这类url地址追加参数变为:http://jb51.net?a=1&b=2

但是怎么知道已经存在相同参数名呢,例如有这种情况:http://jb51.net?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://jb51.net?a=1&a=2被替换”&a=x”格式字符的时候最后一个正好不会被删除,要知道我们循环中每次我们都是把新参数放在最后面的。
上一篇:Javascript Validation for email(正则表达式) 英文翻译
下一篇:asp提取内容中的手机号码,qq,网址的正则代码
一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。