加入收藏 | 设为首页 | 会员中心 | 我要投稿 济宁站长网 (https://www.0537zz.cn/)- 行业智能、边缘计算、专有云、AI硬件、5G!
当前位置: 首页 > 站长资讯 > 评论 > 正文

PHP利用PCRE回溯次数限制绕过某些安全限制

发布时间:2018-12-09 20:21:40 所属栏目:评论 来源:phithon
导读:这次 Code-Breaking Puzzles 中我出了一道看似很简单的题目pcrewaf,将其代码简化如下: ?php functionis_php($data){ returnpreg_match('/?.*[(`;?].*/is',$data); } if(!is_php($input)){ //fwrite($f,$input);... } 大意是判断一下用户输入的内容有没

这里涉及到了正则表达式的「非贪婪模式」。在 NFA 中,如果我输入 UNION/*aaaaa*/SELECT,这个正则表达式执行流程如下:

  • .+? 匹配到/
  • 因为非贪婪模式,所以.+? 停止匹配,而由 S 匹配*
  • S 匹配*失败,回溯,再由.+? 匹配*
  • 因为非贪婪模式,所以.+? 停止匹配,而由 S 匹配 a
  • S 匹配 a 失败,回溯,再由.+? 匹配 a

(编辑:济宁站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读