CIDR网络地址、广播地址、网段区间计算说明与计算工具

文章目录

  • 开始
  • 问题
    • 参考答案
  • 答案解析
  • 计算工具
  • 测试

开始

好久没有看计算网络,感觉已经完全返给老师了。

最近,有同事遇到个问题,网络一直不对,又开始重新看一下。

相信很多朋友长时间不看也忘了,所以,这里记录一下,并提供了一个工具类用来计算相关值。

希望帮助新学习的朋友学习、已经忘了的朋友重新回忆。

觉得自己理解到位的朋友,可以尝试一下下面的问题。

问题

我的IPv4地址是:172.17.1.6,子网掩码是:255.255.252.0

请问:

  1. 我和172.17.0.6在同一网段吗?172.17.2.6呢?172.17.3.6呢?172.17.4.6呢?
  2. 我所在网络的网络地址是多少?网络位数是多少?
  3. 我所在网络的广播地址是多少?
  4. 我所在网络的最小主机IP地址是多少?
  5. 我所在的网络最大主机IP地址是多少?

上面的问题你能回答几个?答对了几个?

参考答案

  1. 172.17.1.6和172.17.0.6、172.17.2.6、172.17.3.6是同一网段,和172.17.4.6不是同一网段
  2. 我所在网络的网络地址:10101100000100010000000000000000(172.17.0.0/22)
  3. 我所在网络的广播地址:10101100000100010000001111111111(172.17.3.255)
  4. 我所在网络的最小主机IP地址:10101100000100010000000000000001(172.17.0.1)
  5. 我所在的网络最大主机IP地址:10101100000100010000001111111110(172.17.3.254)

答案解析

首先算网络地址:
我的IP & 子网掩码就是我所在的网络地址:
我的地址:10101100000100010000000100000110(172.17.1.6)
子网掩码:11111111111111111111110000000000(255.255.252.0)
与有0为0:10101100000100010000000000000000(172.17.0.0)

网络位数,数子网掩码前面1的个数:22,因此网络号可以写成:172.17.0.0/22,很多网策支持这样配置。

广播地址是主机位全为1的地址,因此把网络地址中的主机位全换为1即可:
网络位数是22,所以主机位是10位:10101100000100010000001111111111(172.17.3.255)

最小的主机地址是网络地址+1:10101100000100010000000000000001(172.17.0.1)
最大的主机地址是广播地址-1:10101100000100010000001111111110(172.17.3.254)

有了最小的主机地址和最大的主机地址,现在再看第一个问题,是不是清晰了。

这其中最大的误区就是,一晃眼就认为172.17.1.6的网段是172.17.1.0
这是没有CIDR,在子网掩码为:255.255.255.0时才成立

计算工具

package vip.meet.network.ip;import lombok.extern.slf4j.Slf4j;import java.math.BigInteger;/*** CIDR* 网络中:* 全为0的是:网络地址(最小地址)* 全为1的是:广播地址(最大地址)* 最小可用地址=网络地址+1* 最大可用地址=广播地址-1* <p>* 私有地址:* A类地址范围:10.0.0-10.255.255.255* B类地址范围:172.16.0.0-172.31.255.555* C类地址范围:192.168.0.0-192.168.255.255*/
@Slf4j
public class IpCalculateHelper {/*** 根据主机IP和子网掩码计算网络地址 ip & mask* <p>* 198.1.33.205 :11000110000000010010000111001101* 255.255.252.0:11111111111111111111110000000000* &* 198.1.32.0/22:11000110000000010010000000000000** @param netIp 要计算的ip 198.1.33.205* @param mask  子网掩码 255.255.252.0* @return 网络地址 198.1.32.0*/public static String getIPV4CIDRNet(String netIp, String mask) {String ipv4CIDRBinary = getIPV4CIDRBinary(netIp, mask);return binaryIp2NetIp(ipv4CIDRBinary);}/*** 获取网络二进制地址** @param netIp 198.1.33.205* @param mask  55.255.252.0* @return 11000110000000010010000000000000*/public static String getIPV4CIDRBinary(String netIp, String mask) {BigInteger ipBin = new BigInteger(getIPBinary(netIp), 2);BigInteger maskBin = new BigInteger(getIPBinary(mask), 2);BigInteger result = ipBin.and(maskBin);String string = result.toString(2);return "0".repeat(32 - string.length()) + string;}/*** 二进制转ip转网络ip** @param binaryIp 二进制ip 11000110000000010010000000000000* @return ip 198.1.32.0*/public static String binaryIp2NetIp(String binaryIp) {int length = binaryIp.length();if (length > 32) {throw new RuntimeException("非法ip长度:" + binaryIp);}String pad = "0".repeat(32 - length) + binaryIp;return Integer.valueOf(pad.substring(0, 8), 2) + "." +Integer.valueOf(pad.substring(8, 16), 2) + "." +Integer.valueOf(pad.substring(16, 24), 2) + "." +Integer.valueOf(pad.substring(24), 2);}/*** 二进制ip转ip** @param netIp 198.1.32.0* @return binary ip 二进制ip 11000110000000010010000000000000*/public static String getIPBinary(String netIp) {String[] parts = netIp.split("\\.");if (parts.length != 4) {throw new RuntimeException("非法ipv4:" + netIp);}StringBuilder sb = new StringBuilder();for (String part : parts) {BigInteger integer = new BigInteger(part, 10);String partIp = integer.toString(2);sb.append("0".repeat(8 - partIp.length())).append(partIp);}return sb.toString();}/*** 根据子网掩码算网络位数** @param mask 子网掩码 255.255.252.0* @return 网络位数 22*/public static int getNetBitFromMask(String mask) {String binString = getIPBinary(mask);int count = 0;for (int i = 0; i < binString.length(); i++) {if (binString.charAt(i) != '1') {break;}count++;}return count;}/*** 获取二进制子网掩码** @param netBit 网络位数* @return 二进制子网掩码*/public static String getMaskBinaryFromNetBit(int netBit) {if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}return "1".repeat(netBit) + "0".repeat(32 - netBit);}/*** 获取子网掩码** @param netBit 网络位数* @return 子网掩码*/public static String getMaskFromNetBit(int netBit) {if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}String maskBinary = "1".repeat(netBit) + "0".repeat(32 - netBit);return binaryIp2NetIp(maskBinary);}/*** 获取广播地址** @param binaryCIDR cidr网络 11000110000000010010000000000000* @param netBit     网络位数 22* @return 广播地址 11000110000000010010001111111111*/public static String getBroadcast(String binaryCIDR, int netBit) {if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}return binaryCIDR.substring(0, netBit) + "1".repeat(32 - netBit);}/*** 计算最小主机地址** @param binaryCIDR CIDR网络地址 11000110000000010010000000000000* @return 最小主机地址 1100011000000001001000000000000*/public static String minHostIp(String binaryCIDR) {return binaryCIDR.substring(0, 31) + "1";}/*** 最大主机地址** @param binaryCIDR CIDR网络地址 11000110000000010010000000000000* @param netBit     网络位数 22* @return 最大主机地址 11000110000000010010001111111110*/public static String maxHostIp(String binaryCIDR, int netBit) {if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}return binaryCIDR.substring(0, netBit) + "1".repeat(31 - netBit) + "0";}public static void printNetInfo(String netIp, int netBit) {if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}String mask = getMaskFromNetBit(netBit);printNetInfo(netIp, netBit, mask);}public static void printNetInfo(String netIp, String mask) {int netBit = getNetBitFromMask(mask);printNetInfo(netIp, netBit, mask);}public static void printNetInfo(String netIp, Integer netBit, String mask) {if (netBit == null) {netBit = getNetBitFromMask(mask);}if (netBit < 1 || netBit >= 32) {throw new RuntimeException("非法网络位数:" + netBit);}String ipBinary = getIPBinary(netIp);System.out.printf("二进制IP:%s(%s)\n", ipBinary, netIp);String maskBinary = getIPBinary(mask);System.out.printf("  掩码IP:%s(%s)\n", maskBinary, mask);String ipv4CIDRBinary = getIPV4CIDRBinary(netIp, mask);System.out.printf("  网络IP:%s(%s/%d)\n", ipv4CIDRBinary,binaryIp2NetIp(ipv4CIDRBinary), netBit);String broadcast = getBroadcast(ipv4CIDRBinary, netBit);System.out.printf("  广播IP:%s(%s)\n", broadcast, binaryIp2NetIp(broadcast));String min = minHostIp(ipv4CIDRBinary);System.out.printf(" 最小HIP:%s(%s)\n", min, binaryIp2NetIp(min));String max = maxHostIp(ipv4CIDRBinary, netBit);System.out.printf(" 最大HIP:%s(%s)\n", max, binaryIp2NetIp(max));}
}

测试

 @Test
public void printNetInfo() {IpCalculateHelper.printNetInfo("10.2.2.7", 20);System.out.println("--------------");IpCalculateHelper.printNetInfo("172.17.1.6", "255.255.252.0");System.out.println("--------------");IpCalculateHelper.printNetInfo("192.168.3.3", 21);
}

计算结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/543313.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

详解(实现)堆的接口函数

文章目录 堆堆的顺序存储 准备工作创建头文件Heap.h创建源文件Heap.c头文件的包含定义保存堆数据的结构体 初始化销毁堆插入数据向上调整算法图解算法代码 删除堆顶向下调整算法图解代码 取出堆顶数据求堆的数据个数判断堆是否为空全部代码Heap.hHeap.c 再了解堆之前我们先要了…

云备份项目2

云备份项目 文章目录 云备份项目4. 服务端代码设计4.1 服务端工具类实现4.1.1 文件实用工具类设计4.1.2 Json实用工具类设计 4.2 服务端配置信息模块实现4.2.1 系统配置信息4.2.2 单例文件配置类设计 4.3 服务端数据管理模块实现4.3.1 备份数据类的实现4.3.2 数据管理类的设计 …

[BJDCTF2020]Cookie is so stable

hint提示查看cookies flag.php页面我们先随便输入一个名字 输入后我们重新进一次flag.php&#xff0c;发现cookie里存储了刚刚登陆时输入的用户名&#xff0c;直接猜是ssti 尝试后根据ssti特征判断是twig模板 {{_self.env.registerUndefinedFilterCallback("exec")…

论文阅读——RemoteCLIP

RemoteCLIP: A Vision Language Foundation Model for Remote Sensing 摘要——通用基础模型在人工智能领域变得越来越重要。虽然自监督学习&#xff08;SSL&#xff09;和掩蔽图像建模&#xff08;MIM&#xff09;在构建此类遥感基础模型方面取得了有希望的结果&#xff0c;但…

AI智慧校园电子班牌云平台源码

目录 家长端 学校端 电子围栏 亲情通话 课堂答题 移动化管理模式 统一资源管理平台 模板内容智能更换 家校互联 家长端 多场景通话:上学放学联系、紧急遇险求助联系、日常亲情通话关注孩子人身安全:到校离校情况、进入危险区域预警等。 学校端 课堂秩序管理:提高教…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:Counter)

计数器组件&#xff0c;提供相应的增加或者减少的计数操作。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 子组件 可以包含子组件。 接口 Counter() 从API version 9开始&#xff0c;该接口…

【网站项目】320社区物业管理系统

&#x1f64a;作者简介&#xff1a;拥有多年开发工作经验&#xff0c;分享技术代码帮助学生学习&#xff0c;独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。&#x1f339;赠送计算机毕业设计600个选题excel文件&#xff0c;帮助大学选题。赠送开题报告模板&#xff…

MySQL-HMA 高可用故障切换

本章内容&#xff1a; 了解MySQL MHA搭建MySQL MHAMySQL MHA故障切换 1.案例分析 1.1.1案例概述 目前 MySQL 已经成为市场上主流数据库之一&#xff0c;考虑到业务的重要性&#xff0c;MySQL 数据库 单点问题已成为企业网站架构中最大的隐患。随着技术的发展&#xff0c;MHA…

广度优先算法(一篇文章讲透)

目录 引言 一、算法概述 二、算法步骤 1 初始化 2 循环处理 三、算法应用 1 图的最短路径问题 2 网络爬虫 3 社交网络分析 4 游戏路径搜索 事例 四、算法特点与性能 五、性能优化 1 剪枝策略&#xff1a; 2 使用高效的数据结构&#xff1a; 3 并行化处理&#…

sparksession对象简介

什么是sparksession对象 spark2.0之后&#xff0c;sparksession对象是spark编码的统一入口对象&#xff0c;通常我们在rdd编程时&#xff0c;需要SparkContext对象作为RDD编程入口&#xff0c;但sparksession对象既可以作为RDD编程对象入口&#xff0c;在sparkcore编程中可以通…

这些赚钱项目可以主业副业两不误

在如今竞争激烈的社会中&#xff0c;拥有一份可靠的职业是我们追求稳定收入的首选。然而&#xff0c;为了应对生活成本的不断增加和个人发展的需求&#xff0c;更多的人开始寻求一种既能兼顾主业&#xff0c;又能增加额外收入的副业机会。 生活中有这么一些人&#xff0c;他们将…

YOLOv7 | 添加GSConv,VoVGSCSP等多种卷积,有效提升目标检测效果,代码改进(超详细)

⭐欢迎大家订阅我的专栏一起学习⭐ &#x1f680;&#x1f680;&#x1f680;订阅专栏&#xff0c;更新及时查看不迷路&#x1f680;&#x1f680;&#x1f680; YOLOv5涨点专栏&#xff1a;http://t.csdnimg.cn/QdCj6 YOLOv7专栏&#xff1a; http://t.csdnimg.cn/dy…