模板引擎正则表达式调试小技巧

很久没有遇上PHP难题了,这次正则问题占了一点时间,还是老问题最大回溯、递归限制问题。学习透之后其实并不难修改调试有这类问题的正则。主要是以下几点。

  • 基于正则表达式替换的模板引擎很容易遇上正则表达式最大回溯/递归的限制。
  • 惰性匹配并不可怕,正常情况下模板并不会不够用,往往不会超出限制,discuz的模板引擎就大量使用了。但是因此而不去注意、不去学习,则容易书写错误并遇上问题。
  • 当preg_*返回的是null的时候则要注意了 判断函数是is_null
  • 出错并不可怕,但是最好把错误都完整的输出,这样调试就很容易了
  • 除了输出出错原因,还要输出匹配的文本和使用的正则,这样就很容易调试了
PHP代码
  1. <?php   
  2. if (is_null($tmp)){   
  3.     $error_code = preg_last_error();   
  4.     switch($error_code){   
  5.         case PREG_NO_ERROR :   
  6.             echo 'PREG_NO_ERROR';   
  7.             break;   
  8.         case PREG_INTERNAL_ERROR:   
  9.             echo 'PREG_INTERNAL_ERROR';   
  10.             break;   
  11.         case PREG_BACKTRACK_LIMIT_ERROR:   
  12.             echo 'PREG_BACKTRACK_LIMIT_ERROR';   
  13.             break;   
  14.         case PREG_RECURSION_LIMIT_ERROR:   
  15.             echo 'PREG_RECURSION_LIMIT_ERROR';   
  16.             break;   
  17.         case PREG_BAD_UTF8_ERROR:   
  18.             echo 'PREG_BAD_UTF8_ERROR';   
  19.             break;   
  20.         case PREG_BAD_UTF8_OFFSET_ERROR:   
  21.             echo 'PREG_BAD_UTF8_OFFSET_ERROR';   
  22.             break;   
  23.         default:   
  24.             echo 'UNKNOW ERROR';   
  25.     }   
  26.     exit;   
  27. }  

参考资料

  1. 2011, PHP中文手册 preg_last_error

本文采用Creative Commons协议,复制本文需遵守三点:1、保留署名(链接);2、非商业性使用;3、再次创作的作品必须以相同的许可协议发布。法律顾问:庄毅雄律师

Tags: 最大回溯, 递归限制

« 上一篇 | 下一篇 »

Comment (require):