正则表达式(regex)或操作符”|“使用易出现功能Bug
程序员文章站
2022-11-05 18:06:51
接上一篇: ,我们继续梳理,正则表达式错误使用,导致功能设计漏洞(bug),做web方面,需要掌握的知识很多,网站开发这项工作,在国内也就10多年,很多开发人员,都是通过:...
接上一篇: ,我们继续梳理,正则表达式错误使用,导致功能设计漏洞(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 字符串,并且后面紧跟数字的。在使用”|”字符串,注意它的优先级级别低,如果要优先匹配,可以放入()中。
下一篇: 京东怎么通过认证学历提升白条额度?
推荐阅读
-
Linux中使用cgroups限制cpu资源实例
-
Linux date命令用法和使用技巧(获取今天、昨天、一分钟前等)
-
Unity3D使用GL实现图案解锁功能
-
为何不要在MySQL中使用UTF-8编码方式详解
-
浅谈Java代码的 微信长链转短链接口使用 post 请求封装Json(实例)
-
在手机不方便使用的情况下如何在浏览器上面进行微信版网页版聊天
-
Linux中使用hostname命令修改主机名称(非常简单)
-
Windows7下安装使用MySQL8.0.16修改密码、连接Navicat问题
-
mysql8.0版本skip-grant-tables出现的新问题
-
在Spring Boot中使用Spring-data-jpa实现分页查询