• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    正则表达式(regex)或操作符”|“使用易出现功能Bug

    接上一篇:正则表达式(regex)错误使用导致功能漏洞 ,我们继续梳理,正则表达式错误使用,导致功能设计漏洞(bug),做web方面,需要掌握的知识很多,网站开发这项工作,在国内也就10多年,很多开发人员,都是通过:培训(自学) ->模仿->做项目 ,这样一个过程。很多就是修修改改后,就成为了web开发工程师。这行入门低,很容易上手。但是想成为大师级的,还是很不容易。需要学习,掌握的知识几十门。而对于刚刚入门同人,很多时候因为缺乏系统学习,理论支持。导致提升有些心有余而力不足啦!因此,出现这些或多或少的功能设计漏洞,是很常见的!

    好了,有些跑题了,在做代码走查时候,这类漏洞也是时常出现。我们看下,下面代码:

    ?php
    $user="bcd123张三";
    ///匹配用户名中出现abc还有bcd开头,后面紧跟是数字字符
     
    preg_match_all("/abc|bcd\d+/",$user,$match);
    var_dump($match);
     
    /*结果是
    array(1) {
     [0]=>
     array(1) {
     [0]=>
     string(6) "bcd123"
     }
    }
    */

    查找所有页面出现abc或者bcd开头,后面紧跟数字字符串。通过上面,我们看,正确匹配到bcd123,如果我们输入:$user = “abc123张三”, 发现不能匹配到了。原因是”|”字符,优先级最低,以上写法会变成:匹配abc 或者是bcd\d+ 字符串。

    以上图,将|,包含到()中。

    如果要提升优先级,可以(abc|bcd)\d+ ,匹配所有abc或者bcd 字符串,并且后面紧跟数字的。在使用”|”字符串,注意它的优先级级别低,如果要优先匹配,可以放入()中。

    您可能感兴趣的文章:
    • Java正则表达式处理特殊字符转义的方法
    • 正则表达式字符类加深理解
    • 正则表达式\d元字符(相对于数字0-9)
    • 正则表达式\W元字符使用方法
    • 正则表达式\w元字符使用介绍
    • 利用正则表达式判断一个给定的字符是否是回文
    • 使用正则表达式替换报表名称中的特殊字符(推荐)
    • C#正则表达式转义字符介绍
    • 正则表达式匹配任意字符(包括换行符)的写法
    • 正则表达式匹配不包含某些字符串的技巧
    • 正则表达式教程之操作符及说明详解
    上一篇:正则表达式(regex)错误使用导致功能漏洞分析
    下一篇:正则表达式(regex) 贪婪模式、懒惰模式使用方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    正则表达式(regex)或操作符”|“使用易出现功能Bug 正则,表达式,regex,或,操作,