博客
关于我
Java正则表达式:iPv4的ip地址匹配
阅读量:522 次
发布时间:2019-03-07

本文共 924 字,大约阅读时间需要 3 分钟。

结果

在进行多次测试后,我们发现目标地址的有效性验证规则能够正确识别大部分合法IP地址,仅有一小部分异常情况未能通过验证。以下是测试结果的一部分示例:

IP地址 验证结果
192.168.1.1
255.255.255.255
172.16.254.56
10.10.10.10
255.255.254.255
256.256.256.256

从测试数据来看,该规则在整体上表现良好,但仍有待优化。

表达式解释

我们开发的验证规则基于以下正则表达式进行匹配:

((25[0-5])|(2[0-4]\d)|(1\d{2})|([1-9]\d?)))\.(((25[0-5])|(2[0-4]\d)|(1\d{2})|(\d\d?))\.){2}((25[0-5])|(2[0-4]\d)|(1\d{2})|(\d\d?))
理论上,该规则应能匹配几乎所有有效的私有IP地址格式,包括:

  • 10.0.0.0到10.255.255.255(10.x.x.x)
  • 172.16.0.0到172.31.255.255(172.x.x.x)
  • 192.168.0.0到192.168.255.255(192.168.x.x)
  • 255.255.0.0到255.255.255.255(255.255.x.x)

值得注意的是:

  • 本规则已排除0.0.0.0地址
  • 在Java实现时,需确保使用Pattern.quote()对特殊字符进行转义处理
  • 括号的位置需保持一致,不能随意修改
  • 参考博客

    该规则主要借鉴自helloshrek的博客,该博客提供了详细的解释:

    • \d 表示0-9的任意数字

    • {2} 表示重复两次

    • [0-4] 表示0-4的范围

    • "|" 表示或运算符

    • 括号()用于指定匹配组,规则中括号代表的IP地址各个区间

    • 1\d{2} 表示10.0.0到10.99.99的范围,其中第一位是1

    • 2[0-4]\d 表示20.0.0到24.31.31的范围,最后一位是0-9的任意数字

    • 25[0-5] 表示250.0.0到255.5.255的范围

    • [1-9]\d? 表示10.0.0到99.99.99的范围

    • 每个区段中的\. 表示匹配网段号,需要注意转义

    你可能感兴趣的文章
    MySQL8修改密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    查看>>
    MySQL8修改密码的方法
    查看>>
    Mysql8在Centos上安装后忘记root密码如何重新设置
    查看>>
    Mysql8在Windows上离线安装时忘记root密码
    查看>>
    MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
    查看>>
    mysql8的安装与卸载
    查看>>
    MySQL8,体验不一样的安装方式!
    查看>>
    MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
    查看>>
    Mysql: 对换(替换)两条记录的同一个字段值
    查看>>
    mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
    查看>>
    MYSQL:基础——3N范式的表结构设计
    查看>>
    MYSQL:基础——触发器
    查看>>
    Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
    查看>>
    mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
    查看>>
    mysqldump 参数--lock-tables浅析
    查看>>
    mysqldump 导出中文乱码
    查看>>
    mysqldump 导出数据库中每张表的前n条
    查看>>
    mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
    查看>>
    Mysqldump参数大全(参数来源于mysql5.5.19源码)
    查看>>
    mysqldump备份时忽略某些表
    查看>>