使用正则表达式对输入数字进行匹配

article/2025/9/30 13:32:33

前言:

最近有一个区间范围限制,一般255数字以下的都能在网上薅到,但是需要弄一个int16、int32、int64范围的输入限制......在网上逛了很久都没找到,基本都是从0开始教学那种,我又不想看,觉得写的范围太大了,我就单纯的对数字进行校验,最终还是研究了一点点,先说说自己的理解,0如有觉得不对的地方或者还有更简单的方法,请秃头大佬踢我一jio

正文:

下面会使用到一些元字符,边做边解释。

举例:做一个int8的输入限制,也是就是需要将输入框的限制设置在(-128 ~ 127)

先说0~127的限制范围:

      首先需要先写 ^ $ 两个元字符,这两个的意思就是开始与结束的字符串搭配。如匹配 0~5的整数字符串,则就是 ^ [0-5]$ (中括号为字符范围,匹配指定范围内的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范围内的任意小写字母字符)。

        那如果是 0~15呢,15就是两个字符,需要从右边往左拆分,当第一位数字为1时,第二位数值的取值范围就只能是0~5,所以出现了第一种组合方式 1[0-5],当第一位为0时,也就是不显示十位,只存在个位数,那么第二种组合方式就是[0-9],结合第一种和第二种的组合方式,^(1[0-5]|[0-9])$ 中间的|符号可以理解为或运输,就是既可以匹配1[0-5]的数字,也可以匹配[0-9]的数字,圆括号可以理解为一个组合。此处使用Qt测试代码为:

因为元字符中:

\d

匹配一个数字字符。等价于 [0-9]。

所以此处的 "^(1[0-5]|[0-9])$" 组合方式可以缩写成 "^(1[0-5]|\d)$",因为在Qt中使用\d好像被识别成转义字符了,提示如下面一样:

所以需要将 \d 写成 \\d ,即为  "^(1[0-5]|\\d)$"

 

 那么,至此 0~15 整数的正则表达式就写完了,如果我们这里需要写  -15~15 的取值范围又该怎么弄呢? 一样的只需要将 0~15照着抄过来就行。先写成"^((-1[0-5]|\\d)|(1[0-5]|\\d))$",大家会发现我写了两次0~15的取值范围,中间用到了“|”或运算符,在最左侧加了一个“-”负号,给人的感觉好像是-15~15,但是这里左侧的取值范围存在0的情况,也就是左边的会出现 -0 的匹配,是因为左边的 \\d包含了 0~9的数字,这里面包含了0,所以我们不想要这种情况的出现,只需要将左边的 \\d改为 [1-9]就可以啦,所以-15~15 的匹配方式为 "^((-1[0-5]|[1-9])|(1[0-5]|\\d))$"

当然这只是我的简单理解,可能会存在更好的方式,避免左右两侧重复的匹配字符串太多,而又做不到复用的情况,也请大佬指出。

        最后我们要来匹配一个 int16的取值范围,因为int16的范围为整数 -32768 ~ 32767,所以我们一开始还是先写右边 0~32767的范围,因为写出了右边后(32767),再将左边( -32768)加个符号,对左边的个位数情况(-0)做出处理,就可以啦。

首先0~32767 当前面为3276时,个位数只能匹配 0~7 : 3276[0-7]

       0~32767 当前面为327时,后两位只能匹配 小于60的数字,也就是0~59,即个位数匹配 0~9,十位数匹配 0~5 : 327[0-5][0-9]  或则 327[0-5]\\d

        0~32767 当前面为32时,后三位只能匹配 小于700的数字,也就是0~699,即个位数匹配 0~9,十位数匹配 0~9,百位数匹配 0~6 : 32[0-6][0-9][0-9]  或则 32[0-6]\\d\\d  也可以简写成 32[0-6]\\d{2}  花括号为前面一个字符重复的次数,这里也就是\\d必须要重复2次。下面是花括号的使用讲解。

{n}

n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。

{n,}

n 是一个非负整数。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。

{n,m}

m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。

        0~32767 当前面为3时,后四位只能匹配 小于2000的数字,也就是0~1999,即个位数匹配 0~9,十位数匹配 0~9,百位数匹配 0~9,千位数匹配0~1 : 3[0-1][0-9][0-9][0-9]  或则 3[0-1]\\d\\d\\d  也可以简写成 3[0-1]\\d{3}。

        0~32767 当存在5位数字,也就是输入数字为万位的时候,那么现在万位只能存在1~2(因为3已经在前面匹配过来,这里不需要继续匹配3的情况了),后四位就可以全匹配0~9,因为只要存在5个数,且万位数字又是1~2的范围内,所以个位、十位、百位、千位再大也不可能会超过30000的 ,即个位数匹配 0~9,十位数匹配 0~9,百位数匹配 0~9,千位数匹配0~9 : [1-2][0-9][0-9][0-9][0-9]  或则 [1-2]\\d\\d\\d\\d  也可以简写成 [1-2]\\d{4}。

        0~32767 当存在4位数字,也就是输入数字为千位的时候,那么现在千位就能存在1~9,后面的百位、十位、个位的取值情况可以为0~9,即千位存在[1-9]\\d\\d\\d,百位存在[1-9]\\d\\d,十位位存在[1-9]\\d,(这里个位为一个数字的情况,留到最后处理)这么组合下来就是 [1-9]\\d\\d\\d|[1-9]\\d\\d|[1-9]\\d,这样匹配没有问题,但是展示不太好,所以这里用到花括号简写为:  [1-9]\\d{1,3}  花括号1~3的意思就是匹配\\d至少一次,最多3次。

        0~32767 当只存在1位数字,也就是只输出个位的时候,即\\d或者[0-9]。

        所以结合上面的匹配结果  0~32767的匹配公式为

"^(3276[0-7]|327[0-5]\\d|32[0-6]\\d{2}|3[0-1]\\d{3}|[1-2]\\d{4}|[1-9]\\d{1,3}|\\d)$"

        那么同理-32768 ~ -1,因为不存在-0的情况,而前面0~32767已经匹配了0,所以此处只匹配到-1。即:

"^-(3276[0-8]|327[0-5]\\d|32[0-6]\\d{2}|3[0-1]\\d{3}|[1-2]\\d{4}|[1-9]\\d{0,3})$"

        那么-32768 ~ 32767的匹配公式,也就是int16的匹配公式为

"^(-(3276[0-8]|327[0-5]\\d|32[0-6]\\d{2}|3[0-1]\\d{3}|[1-2]\\d{4}|[1-9]\\d{0,3})|(3276[0-7]|327[0-5]\\d|32[0-6]\\d{2}|3[0-1]\\d{3}|[1-2]\\d{4}|[1-9]\\d{1,3}|\\d))$"

 同理,int32(-2147483648 ~ 2147483647)、int64(-9223372036854775808 ~ 9223372036854775807)也可以按照这样的方式匹配,当然这只是我简单看了一下后的理解,可能存在还有更简单的方法,欢迎各位大佬赐教。


http://chatgpt.dhexx.cn/article/JjoKfBx4.shtml

相关文章

Python-正则表达式匹配数字

re.match和re.search的区别&#xff1a; re.match 尝试从字符串的起始位置匹配一个模式&#xff0c;如果不是起始位置匹配成功的话&#xff0c;match()就返回none&#xff1b; re.search 扫描整个字符串并返回第一个成功的匹配。 匹配 字符串里面的全部数字&#xff1a;\d 例…

常用正则表达式汇总—(数字匹配/字符匹配/特殊匹配)

匹配大写字母开头单词 r"\b[A-Z][a-z]*\b" r"\b[A-Z]\w*\b"匹配数字 r"\s(-?\d\.?/?\d*%?)"替换日期 2019-09-09 换成 2019.09.09 r"\d{4}-\d{1,2}-\d{1,2}"比较常用的几个正则表达式(匹配数字)评…

【质量】镜像漏洞扫描工具Trivy原理和操作

目录 Trivy工作原理 cve ID和CVE数据库 Trivy扫描镜像流程 快速入门 Trivy工作原理 cve ID和CVE数据库 个人理解&#xff1a; 当有人发现漏洞时&#xff0c;在社区提交漏洞&#xff0c;然后被cve 官方数据库收录&#xff0c;分配cve id。 漏洞扫描工具扫描镜像内的组件…

基于JAVA_Swing的图形化GUI漏洞扫描工具开发的编程思维

文章目录 前言一、工具外观整体设计二、漏洞检测类模块总结2022年6月27日更新此篇 前言 CSDN博客有很长一段时间没有更新&#xff0c;漏洞复现的文章也没有经常发了&#xff0c;原因是因为我这段时间在做一件大事&#xff0c;并且这件大事已经做完啦&#xff01;&#xff01;&…

Xray-强大的漏洞扫描工具

Xray是什么&#xff1f; xray (https://github.com/chaitin/xray) 是从长亭洞鉴核心引擎中提取出的社区版漏洞扫描神器&#xff0c;支持主动、被动多种扫描方式&#xff0c;自备盲打平台、可以灵活定义 POC&#xff0c;功能丰富&#xff0c;调用简单&#xff0c;支持 Windows …

Java 漏洞扫描工具之 IDE 插件中强烈建议修复的漏洞

近期有很多同学在找【漏洞扫描工具】&#xff0c;今天来推荐下这款开源组件的漏洞检测工具&#xff1a;使用简单、能力专业、风险展示清晰的 ide 插件“murphysec”。 它可以快速识别项目中使用了哪些存在安全缺陷的开源组件&#xff0c;并帮助一键修复问题。目前支持Java、Ja…

Web安全 Acunetix漏洞扫描工具.

Acunetix 漏洞扫描工具概括 Acunetix 是一个自动化的 Web 应用程序安全测试工具&#xff0c;是通过检查 SQL 注入&#xff0c;跨站点脚本&#xff08;XSS&#xff09;和其他可利用漏洞等来审核您的 Web 应用程序。一般来说&#xff0c;Acunetix 能够扫描任何通过网络浏览器访问…

idea漏洞扫描工具SonarLint

目的 在使用持续集成发布时&#xff0c;其中加入了sonar的校验&#xff0c;为了提高sonar校验评分&#xff0c;希望在本地进行体检校验。 方案 在idea中安装代码校验插件&#xff0c;这里使用SonarLint | Code Quality and Code Security starts in your IDE&#xff0c;其他还…

【网安神器篇】——WPScan漏洞扫描工具

作者名&#xff1a;Demo不是emo 主页面链接&#xff1a;主页传送门创作初心&#xff1a;舞台再大&#xff0c;你不上台&#xff0c;永远是观众&#xff0c;没人会关心你努不努力&#xff0c;摔的痛不痛&#xff0c;他们只会看你最后站在什么位置&#xff0c;然后羡慕或鄙夷座右…

基于JavaFx的ThinkPHP漏洞扫描工具---RexHa(Aazhen)的一些说明

文章目录 吹水环节一、工具的功能&#xff08;新旧版本对比&#xff09;二、工具的使用与操作2.1 工具新旧版展示2.2 漏洞单个扫描验证功能展示2.2.1 Thinkphp-2.x rce--&#x1f44c;&#x1f3fb;2.2.2 ThinkPHP-5.0.23-RCE--&#x1f44c;&#x1f3fb;2.2.3 ThinkPHP5.0.x-…

漏洞扫描程序

什么是漏洞 漏洞是任何软件中存在的安全漏洞。如果被利用&#xff0c;这些缺陷可能允许攻击者未经授权访问敏感信息&#xff0c;或者通常造成严重破坏&#xff0c;使整个组织面临风险。外部安全研究人员和相关供应商不断审查公开可用的软件以识别漏洞。任何发现的漏洞都会使用…

Web安全 Nessus漏洞扫描工具.

Nessus的概括 Nessus 是世界上很流行的漏洞扫描程序&#xff0c;全世界很多组织都有在使用它。该工具提供完整的电脑漏洞扫描服务&#xff0c;并随时更新其漏洞数据库。Nessus不同于传统的漏洞扫描软件&#xff0c;Nessus可同时在本机或远端上遥控&#xff0c;进行系统的漏洞分…

用于渗透测试的10种漏洞扫描工具

漏洞扫描工具是IT部门中必不可少的工具之一&#xff0c;因为漏洞每天都会出现&#xff0c;给企业带来安全隐患。 漏洞扫描工具有助于检测安全漏洞、应用程序、操作系统、硬件和网络系统。 黑客在不停的寻找漏洞&#xff0c;并且利用它们谋取利益。网络中的漏洞需要及时识别和…

漏洞扫描工具之nessus

5.1 使用Nessus Nessus号称是世界上最流行的漏洞扫描程序&#xff0c;全世界有超过75000个组织在使用它。该工具提供完整的电脑漏洞扫描服务&#xff0c;并随时更新其漏洞数据库。Nessus不同于传统的漏洞扫描软件&#xff0c;Nessus可同时在本机或远端上遥控&#xff0c;进行系…

漏洞扫描工具(一)

FSCAN fscan 是一个内网综合扫描工具&#xff0c;方便一键自动化、全方位漏洞扫描。 它支持主机存活探测、端口扫描、常见服务的爆破、ms17010、redis批量写公钥、计划任务反弹shell、读取win网卡信息、web指纹识别、web漏洞扫描、netbios探测、域控识别等功能。 源码链接&a…

Windows7之天镜漏洞扫描工具安装

01 天镜漏洞扫描工具安装 01 安装天镜 02 升级漏洞 03 重启win7, 多次重复升级过程(1次可能没办法成功) 04 成功之后查看版本

AWVS-Web漏洞扫描工具

一、AWVS简介 Acunetix Web Vulnerability Scanner&#xff08;简称AWVS&#xff09;是一个自动化的Web漏洞扫描工具&#xff0c;它可以扫描任何通过Web浏览器访问和遵循HTTP/HTTPS规则的Web站点。 AWVS原理是基于漏洞匹配方法&#xff0c;通过网络爬虫测试你的网站安全&…

如何自己开发漏洞扫描工具

漏洞扫描工具&#xff0c;核心就是扫描器&#xff0c;而扫描器的设计思想是&#xff1a;灵活&#xff0c;易扩展&#xff0c;易修改&#xff0c;灵活的意思就是可单独执行专项漏洞的扫描&#xff0c;也可以批量执行集成的所有漏洞探测模块&#xff1b;易扩展的意思就是&#xf…

漏洞扫描工具openvas

openvas简介 安装环境 安装openvas 一系统简介 OpenVAS是开放式漏洞评估系统&#xff0c;也可以说它是一个包含着相关工具的网络扫描器。其核心部件是一个服务器&#xff0c;包括一套网络漏洞测试程序&#xff0c;可以检测远程系统和应用程序中的安全问题。 用户需要一种自动…

漏洞扫描工具汇总

漏洞扫描器可以快速帮助我们发现漏洞&#xff0c;如SQL注入漏洞、CSRF、缓冲区溢出等。下面就介绍几种常用的漏洞扫描工具。 Fortify 代码审计工具Fortify SCA (Fortify Static Code Analyzer)&#xff0c;一款软件代码安全测试工具&#xff0c;提供静态源码扫描能力&#xf…