首页 > 其他分享 >校验IP地址格式:IPv4、IPv6、IP/掩码和IP段

校验IP地址格式:IPv4、IPv6、IP/掩码和IP段

时间:2024-07-03 09:08:49浏览次数:13  
标签:return IP IPv4 IP地址 掩码 格式

校验IP地址格式:IPv4、IPv6、IP/掩码和IP段

https://www.jianshu.com/p/95d51e51cc2e

IPv4 格式验证

IPv4是32位地址,由四个十进制数(0-255)组成,以点分隔。以下是一个IPv4地址的示例:192.168.0.1。

要验证输入是否符合IPv4格式,我们可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IPv4地址的格式:

function isValidIPv4Format(ip) {
  const ipRegex = /^(\d{1,3}\.){3}\d{1,3}$/;
  return ipRegex.test(ip);
}

该函数接受一个IP地址作为参数,并返回一个布尔值来指示是否符合IPv4格式。

IPv6 格式验证

IPv6是128位地址,由八个四位的十六进制数(0-9、A-F)组成,以冒号分隔。以下是一个IPv6地址的示例:2001:0db8:85a3:0000:0000:8a2e:0370:7334。

要验证输入是否符合IPv6格式,我们同样可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IPv6地址的格式:

function isValidIPv6Format(ip) {
  const ipRegex = /^([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}$/;
  return ipRegex.test(ip);
}

该函数接受一个IP地址作为参数,并返回一个布尔值来指示是否符合IPv6格式。

IP/掩码验证

在网络配置中,常见的情况是将IP地址与子网掩码组合在一起。例如:192.168.0.1/24。这种形式被称为IP/掩码格式。

要验证输入是否符合IP/掩码格式,我们可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IP/掩码格式:

function isValidIPWithMaskFormat(ipWithMask) {
  const ipWithMaskRegex = /^(\d{1,3}\.){3}\d{1,3}\/(1[0-9]|2[0-9]|3[0-2]|\d)$/;
  return ipWithMaskRegex.test(ipWithMask);
}

该函数接受一个IP/掩码作为参数,并返回一个布尔值来指示是否符合IP/掩码格式。

IP段校验

有时候我们需要校验IP地址的范围,即IP段。例如:192.168.0.1~192.168.0.10。

要验证输入是否符合IP段格式,我们首先需要检查两个IP地址是否都是有效的IP地址,并且前者小于等于后者。下面是一个JavaScript函数用于判断IP段格式:

function isValidIPRange(ip1, ip2) {
  function isIPv4Address(ip) {
    // IPv4地址验证逻辑
  }

  function isIPv6Address(ip) {
    // IPv6地址验证逻辑
  }

  if ((isIPv4Address(ip1) || isIPv6Address(ip1)) && (isIPv4Address(ip2) || isIPv6Address(ip2))) {
    // 验证IP段范围的逻辑
    return true;
  }
  
  return false;
}

该函数接受两个IP地址作为参数,并返回一个布尔值来指示是否符合IP段格式。

通过以上的函数,我们可以在表单中进行IP地址的格式检查和校验。根据需要调用相应的函数,并显示相应的提示信息给用户。

在实际应用中,我们可以使用JavaScript、Python或其他编程语言来实现这些功能。上述代码当处理网络相关的应用程序时,IP地址是一个常见的概念。IPv4和IPv6是当前广泛使用的两种IP地址格式,而IP/掩码和IP段校验是验证IP地址的有效性的常见需求。本文将介绍如何在表单中进行IP地址的格式检查和校验。

IPv4 格式验证

IPv4是32位地址,由四个十进制数(0-255)组成,以点分隔。以下是一个IPv4地址的示例:192.168.0.1。

要验证输入是否符合IPv4格式,我们可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IPv4地址的格式:

function isValidIPv4Format(ip) {
  const ipRegex = /^(\d{1,3}\.){3}\d{1,3}$/;
  return ipRegex.test(ip);
}

该函数接受一个IP地址作为参数,并返回一个布尔值来指示是否符合IPv4格式。

IPv6 格式验证

IPv6是128位地址,由八个四位的十六进制数(0-9、A-F)组成,以冒号分隔。以下是一个IPv6地址的示例:2001:0db8:85a3:0000:0000:8a2e:0370:7334。

要验证输入是否符合IPv6格式,我们同样可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IPv6地址的格式:

function isValidIPv6Format(ip) {
  const ipRegex = /^([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}$/;
  return ipRegex.test(ip);
}

该函数接受一个IP地址作为参数,并返回一个布尔值来指示是否符合IPv6格式。

IP/掩码验证

在网络配置中,常见的情况是将IP地址与子网掩码组合在一起。例如:192.168.0.1/24。这种形式被称为IP/掩码格式。

要验证输入是否符合IP/掩码格式,我们可以使用正则表达式进行匹配。下面是一个JavaScript函数用于判断IP/掩码格式:

function isValidIPWithMaskFormat(ipWithMask) {
  const ipWithMaskRegex = /^(\d{1,3}\.){3}\d{1,3}\/(1[0-9]|2[0-9]|3[0-2]|\d)$/;
  return ipWithMaskRegex.test(ipWithMask);
}

该函数接受一个IP/掩码作为参数,并返回一个布尔值来指示是否符合IP/掩码格式。

IP段校验

有时候我们需要校验IP地址的范围,即IP段。例如:192.168.0.1~192.168.0.10。

要验证输入是否符合IP段格式,我们首先需要检查两个IP地址是否都是有效的IP地址,并且前者小于等于后者。下面是一个JavaScript函数用于判断IP段格式:

function isValidIPRange(ip1, ip2) {
  function isIPv4Address(ip) {
    // IPv4地址验证逻辑
  }

  function isIPv6Address(ip) {
    // IPv6地址验证逻辑
  }

  if ((isIPv4Address(ip1) || isIPv6Address(ip1)) && (isIPv4Address(ip2) || isIPv6Address(ip2))) {
    // 验证IP段范围的逻辑
    return true;
  }
  
  return false;
}

该函数接受两个IP地址作为参数,并返回一个布尔值来指示是否符合IP段格式。

通过以上的函数,我们可以在表单中进行IP地址的格式检查和校验。根据需要调用相应的函数,并显示相应的提示信息给用户。

/**
 * ipv4 格式
 * IP 格式
 * ip/掩码
 * ip1~ip2(ip段)
 *
 */
export function isValidIPv4Format(value) {
  // 判断是否为有效的 IPv4 地址
  const isIPv4Address = (ip) => {
    const ipRegex = /^(\d{1,3}\.){3}\d{1,3}$/;
    return ipRegex.test(ip);
  };

  // 判断是否为有效的 IPv4/掩码
  const isIPv4WithMask = (ipWithMask) => {
    const ipWithMaskRegex = /^(\d{1,3}\.){3}\d{1,3}\/(1[0-9]|2[0-9]|3[0-2]|\d)$/;
    return ipWithMaskRegex.test(ipWithMask);
  };

  // 判断是否为有效的 IPv4 段
  const isIPv4Range = (ip1, ip2) => {
    if (!isIPv4Address(ip1) || !isIPv4Address(ip2)) {
      return false; // 不是有效的 IPv4 地址
    }

    const ipParts1 = ip1.split('.');
    const ipParts2 = ip2.split('.');

    for (let i = 0; i < 4; i++) {
      if (parseInt(ipParts1[i], 10) > parseInt(ipParts2[i], 10)) {
        return false; // ip1 大于 ip2
      }
      if (parseInt(ipParts1[i], 10) === parseInt(ipParts2[i], 10)) {
        continue; // 当前段相等,继续检查下一段
      }
      return true; // ip1 小于 ip2
    }

    return true; // ip1 等于 ip2
  };
  if (isIPv4Address(value)) {
    return true;
    // return 'IPv4 地址格式';
  } else if (isIPv4WithMask(value)) {
    return true;
    // return 'IPv4/掩码格式';
  } else if (value.includes('~') && value.split('~').length === 2 && isIPv4Range(...value.split('~'))) {
    // return 'IPv4 段格式';
    return true;
  } else {
    return 'IP格式错误';
  }
}


/**
 * ipv6 格式
 * IP 格式
 * ip/掩码
 * ip1~ip2(ip段)
 *
 */
export function isValidIPv6Format(value) {
  // 判断是否为有效的 IPv6 地址
  const isIPv6Address = (ip) => {
    const ipRegex = /^([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}$/;
    return ipRegex.test(ip);
  };

  // 判断是否为有效的 IPv6/掩码
  const isIPv6WithMask = (ipWithMask) => {
    const ipWithMaskRegex = /^([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}\/(12[0-8]|1[01]\d|\d{1,2})$/;
    return ipWithMaskRegex.test(ipWithMask);
  };

  // 判断是否为有效的 IPv6 段
  const isIPv6Range = (ip1, ip2) => {
    if (!isIPv6Address(ip1) || !isIPv6Address(ip2)) {
      return false; // 不是有效的 IPv6 地址
    }

    const ipParts1 = ip1.split(':');
    const ipParts2 = ip2.split(':');

    for (let i = 0; i < 8; i++) {
      if (parseInt(ipParts1[i], 16) > parseInt(ipParts2[i], 16)) {
        return false; // ip1 大于 ip2
      }
      if (parseInt(ipParts1[i], 16) === parseInt(ipParts2[i], 16)) {
        continue; // 当前段相等,继续检查下一段
      }
      return true; // ip1 小于 ip2
    }

    return true; // ip1 等于 ip2
  };

  if (isIPv6Address(value)) {
    return true;
  } else if (isIPv6WithMask(value)) {
    return true;
  } else if (value.includes('~') && value.split('~').length === 2 && isIPv6Range(...value.split('~'))) {
    return true;
  } else {
    return 'IP格式错误';
  }
}

标签:return,IP,IPv4,IP地址,掩码,格式
From: https://www.cnblogs.com/ff2ting/p/18280929

相关文章

  • TypeScript使用
    检查TypeScript配置:确保您的Vue项目已正确配置TypeScript。您可以检查是否安装了@vue/cli-plugin-typescript插件,并且tsconfig.json文件配置正确。类型定义:确保您正确定义了变量、函数和组件的类型。在Vue组件中,可以使用TypeScript的类型保护帮助我明确变量的类型在T......
  • JavaScript-WebAPI
    文章目录JS组成什么是webApis和APIDOM简介document对象获取DOM对象利用css选择器来获取DOM元素选择指定css选择器的所有元素其他获取DOM元素方法(了解)操作元素内容对象.innerText对象.innerHTML操作元素属性操作元素常用属性操作元素样式属性通过style属性操作......
  • Linux统计日志中有多少个不同的IP登录
    题目解析知识点:1、awk-F'''{print$3}'指定空格是分隔符进行分割,取第三个。(不指定默认分隔符也是空格)2、uniq-c(uniq命令可以去除排序过的文件中的重复行,因此uniq经常和sort合用。也就是说,为了使uniq起作用,所有的重复行必须是相邻的。参数-c:进行计数)3、wc-l行......
  • zip-zip(子函数调用)
    题目监听服务器端口,得到题目如下:源码解析主函数主函数中是题目界面的逻辑,对应于用户的选择做出相应的操作,其中需要注意的是选项2,解压操作需要获得root权限(uid==0).选项1,2:文件压缩和解压缩,是常规的文件压缩代码,不做解释。选项3:buy操作,buy()函数调用了加密函数en......
  • LLaMA-Factory/scripts/length_cdf.py 源码解析
    这段代码定义了一个函数 length_cdf,用来计算和打印数据集样本长度的累积分布函数(CDF),并在脚本直接运行时通过 fire 库将该函数暴露为命令行接口。我们逐行解释这段代码:python复制fromllmtuner.dataimportget_datasetfromllmtuner.hparamsimportget_train_argsfrom......
  • 如何通过指纹浏览器使用代理IP?
    1.指纹浏览器定义指纹浏览器是&nbsp;一种浏览器技术,它根据用户设备的硬件、软件和配置等特征生成唯一标识符(称为“指纹”)。此指纹用于识别和追踪用户身份,即使用户更改其IP地址或清除浏览器数据(如缓存和Cookie)也是如此。指纹浏览器会&nbsp;收集用户设备的信息,包括操作系统......
  • 代理IP的10大误区:区分事实与虚构
    在当今的数字时代,代理已成为在线环境不可或缺的一部分。它们的用途广泛,从增强在线隐私到绕过地理限制。然而,尽管代理无处不在,但仍存在许多围绕代理的误解。在本博客中,我们将探讨和消除一些最常见的代理误解,阐明其真实性质和用法。1.代理保证绝对匿名关于代理的最普遍误解之......
  • iperf详解与实践
    iperf详解与实践目录iperf详解与实践1、iperf介绍1.1简介1.2iperf的主要特点包括:1.3iperf主要测试什么1.4iperf和iperf3区别2、iperf的主要参数说明2.1客户端2.2服务端2.3公共使用3、iperf安装配置示例3.1下载win的iperf版本3.2linux客户端测3.2.1源码编译安装ipe......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript运动网站(田径)
    HTML+CSS+JS【运动网站】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......
  • 大学生HTML期末大作业——HTML+CSS+JavaScript购物商城(Oppo)
    HTML+CSS+JS【购物商城】网页设计期末课程大作业web前端开发技术web课程设计网页规划与设计......