解决preg_match匹配过多字符长度的限制的思路分析


但是官方的文档里面没有说明这一点。

于是开始测试:将要匹配的字串不断缩短,直到缩为原来1/5的时候可以正常匹配了,所以更加确定了。

到google里一搜,终于找到了解决方案:在php.ini中加入(随便放到哪里,我是直接放第一行的)

pcre.backtrack_limit=-1

再次使用preg_match函数测试一下,大概1300多行上万个字符的字符串也能够匹配了。

项目中,用preg_match正则提取目标内容,死活有问题,代码测得死去活来。

后来发现“pcre.backtrack_limit ”的值默认只设了100000。

解决办法:ini_set(‘pcre.backtrack_limit', 999999999);

注:这个参数在php 5.2.0版本之后可用。

另外说说关于:pcre.recursion_limit

pcre.recursion_limit是PCRE的递归限制,这个项如果设很大的值,会消耗所有进程的可用堆栈,最后导致PHP崩溃。

也可以通过修改配置来限制:ini_set(‘pcre.recursion_limit', 99999);

实际项目应用中,最好也对内存进行限定设置:ini_set(‘memory_limit', '64M'); , 这样就比较稳妥妥嘎。

学习正则!超基础简单例子
问题是这样的,某个情况下要给:http://gimoo.net?a=1这类url地址追加参数变为:http://gimoo.net?a=1&b=2但是怎么知道已经存在相同参数名呢,例如有这种情况

匹配5到10位无重复数字的正则表达式
对于有重复的5到10位数字可以使用d{5,10}这样的正则无重复的5到10位数字我考虑了一下还不会,最然只好查网上。有一个版本还不错,反正RegexBuddy测试

DW 查找某字符串前的所有字符的正则表达式
我使用DW这个所见所得的编辑器来写html时,喜欢写上注释,如!--header--等等的注释,在一次比较大的改动时,需要批量查找替换,为了批量操作,于是我