加入收藏 | 设为首页 | 网站地图 | RSS订阅
阅读内容

PHP教程基于正则表达式替换的模板引擎

日期:2011-6-15     来源:不详     作者:5i93.com收集

    很久没有遇上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、2010, Laruence

    2、2011, PHP中文手册

发表评论】【告诉好友】【打印此文】【收藏此文】【关闭窗口

本文评论
推荐广告
关于本站 | 版权声明 | 免责声明 | 联系我们 | 广告服务 | 加入收藏 | 网站地图 | 网站搜索 | RSS订阅