不管用什么语言开发,我们有时候都会遇到这样一种情况,那就是一个小问题花费几天时间才能解决,这不,昨天遇到PHP模板引擎正则表达式的问题,花了很多时间。
基于正则表达式替换的模板引擎很容易遇上正则表达式最大回溯/递归的限制。
惰性匹配并不可怕,正常情况下模板并不会不够用,往往不会超出限制,discuz的模板引擎就大量使用了。但是因此而不去注意、不去学习,则容易书写错误并遇上问题。
当preg_*返回的是null的时候则要注意了,判断函数是is_null.
出错并不可怕,但是最好把错误都完整的输出,这样调试就很容易了。
除了输出出错原因,还要输出匹配的文本和使用的正则,这样就很容易调试了。
PHP代码
- <?php
- if (is_null($tmp)){
- $error_code = preg_last_error();
- switch($error_code){
- case PREG_NO_ERROR :
- echo 'PREG_NO_ERROR';
- break;
- case PREG_INTERNAL_ERROR:
- echo 'PREG_INTERNAL_ERROR';
- break;
- case PREG_BACKTRACK_LIMIT_ERROR:
- echo 'PREG_BACKTRACK_LIMIT_ERROR';
- break;
- case PREG_RECURSION_LIMIT_ERROR:
- echo 'PREG_RECURSION_LIMIT_ERROR';
- break;
- case PREG_BAD_UTF8_ERROR:
- echo 'PREG_BAD_UTF8_ERROR';
- break;
- case PREG_BAD_UTF8_OFFSET_ERROR:
- echo 'PREG_BAD_UTF8_OFFSET_ERROR';
- break;
- default:
- echo 'UNKNOW ERROR';
- }
- exit;
- }
|
|