博客
关于我
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的范围

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

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>