很久没有遇上PHP难题了这次正则问题占了一点时间还是老问题最大回溯递归限制问题学习透之后其实并不难修改调试有这类问题的正则主要是以下几点 基于正则表达式替换的模板引擎很容易遇上正则表达式最大回溯/递归的限制 惰性匹配并不可怕正常情况下模板并不会不够用往往不会超出限制discuz的模板引擎就大量使用了但是因此而不去注意不去学习则容易书写错误并遇上问题 当preg_*返回的是null的时候则要注意了判断函数是is_null 出错并不可怕但是最好把错误都完整的输出这样调试就很容易了 除了输出出错原因还要输出匹配的文本和使用的正则这样就很容易调试了 PHP代码 - <?php
- if(is_null($tmp)){
- $error_code=preg_last_error();
- switch($error_code){
- casePREG_NO_ERROR:
- echoPREG_NO_ERROR;
- break;
- casePREG_INTERNAL_ERROR:
- echoPREG_INTERNAL_ERROR;
- break;
- casePREG_BACKTRACK_LIMIT_ERROR:
- echoPREG_BACKTRACK_LIMIT_ERROR;
- break;
- casePREG_RECURSION_LIMIT_ERROR:
- echoPREG_RECURSION_LIMIT_ERROR;
- break;
- casePREG_BAD_UTF_ERROR:
- echoPREG_BAD_UTF_ERROR;
- break;
- casePREG_BAD_UTF_OFFSET_ERROR:
- echoPREG_BAD_UTF_OFFSET_ERROR;
- break;
- default:
- echoUNKNOWERROR;
- }
- exit;
- }
参考资料 Laruence 《深悉正则(pcre)最大回溯/递归限制》 PHP中文手册 preg_last_error |