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.rhkb.cn/news/276791.html

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

相关文章

常见的软件系统性能测试指标

常见的软件系统性能测试指标 衡量一个软件系统性能的好坏&#xff0c;在性能测试中会使用一些性能指标来进行分析和描述&#xff0c;以下是一些最常用的性能指标。 1.2.1 响应时间 请求或者某个操作从发出的时间到收到服务器响应的时间的差值就是响应时间。在性能测试中&am…

sqllab第二十三关通关笔记

知识点&#xff1a; mysqli_query() 返回值为资源型或布尔型如果内容为查询语句则返回资源型数据&#xff1b;如果内容为插入、更新、删除等语句则返回布尔类型结果mysql_fetch_array() 从结果集中取出一行作为关联数组或数字数组输入内容为指定查询的结果集单引号闭合绕过联…

位运算#蓝桥杯

位运算#蓝桥杯 文章目录 位运算#蓝桥杯1、小蓝学位运算2、异或森林3、位移4、笨笨的机器人5、博弈论 1、小蓝学位运算 #include<bits/stdc.h> using namespace std; using LL long long; const LL N 1e97; template<int kcz> struct ModInt { #define T (*this)…

C# Chart曲线控件专题

1.控件基本设置 chart1.ChartAreas[0].AxisY.IsStartedFromZero false; //设置Y轴自适应chart1.Series["瞬时值"].BorderWidth 2; // 设置曲线宽度为2个像素&#xff0c;注意[]中写入的Series的Namechart1.Series["瞬时值"].Color Color.Red; // 设置曲…

解决:黑马webpack视频中出现的问题总结

问题 1 ERROR in main Module not found: Error: Can‘t resolve ‘./src‘ 解决 Webpack 中 ERROR in main Module not found: Error: Can‘t resolve ‘./src‘ 问题 黑马AJAX-Node.js-Webpack教学视频&#xff08;BV1MN411y7pw 其中P98&#xff09;中webpack部分&#xff0c…

OCP NVME SSD规范解读-12.Telemetry日志要求

以NVME SSD为例&#xff0c;通常大家想到的是观察SMAR-log定位异常&#xff0c;但是这个信息在多数情况下无法只能支撑完整的定位链路。 定位能力的缺失和低效是数据中心问题解决最大的障碍。 为了解决这个问题&#xff0c;Meta的做法是推进OCP组织加入延迟记录页面。同时NVME协…

设计模式——结构型模式

结构型模式描述如何将类或对象按某种布局组成更大的结构。它分为类结构型模式和对象结构型模式&#xff0c;前者采用继承机制来组织接口和类&#xff0c;后者釆用组合或聚合来组合对象。 由于组合关系或聚合关系比继承关系耦合度低&#xff0c;满足“合成复用原则”&#xff0…

Laravel Class ‘Facade\Ignition\IgnitionServiceProvider‘ not found 解决

Laravel Class Facade\Ignition\IgnitionServiceProvider not found 问题解决 问题 在使用laravel 更新本地依赖环境时&#xff0c;出现报错&#xff0c;如下&#xff1a; 解决 这时候需要更新本地的composer&#xff0c;然后在更新本地依赖环境。 命令如下&#xff1a; co…

【高通camera hal bug分析】高通自带相机镜像问题

首先打了两个log&#xff0c;一个是开启镜像的log&#xff0c;还有一个是没有开启镜像的log&#xff0c;如果我们开启镜像以后&#xff0c;观察开启镜像log发现 , 这段代码走的没有任何问题&#xff0c;因为Flip的值等于1了。 关闭镜像log如下&#xff1a; 如果我们不开启镜像…

腾讯地图的(地图选点|输入模糊匹配)

1.支持用户输入框输入进行模糊匹配获取详细地址以及经纬度2.支持用户模糊匹配后点击选点获取详细地址以及经纬度 1.支持用户输入框输入进行模糊匹配获取详细地址以及经纬度2.支持用户模糊匹配后点击选点获取详细地址以及经纬度 <template><div class"tencentMap-…

lua脚本的基础内容

官方地址&#xff1a;http://luajit.org/ 官方wiki地址&#xff1a;http://wiki.luajit.org/Home 推荐书籍&#xff1a; OpenResty 最佳实践&#xff1a;https://moonbingbing.gitbooks.io/openresty-best-practices/content/ lua基础文档&#xff1a;https://www.runoob.com/l…

力扣大厂热门面试算法题 33-35

33. 搜索旋转排序数组&#xff0c;34. 在排序数组中查找元素的第一个和最后一个位置 &#xff0c;35. 搜索插入位置&#xff0c;每题做详细思路梳理&#xff0c;配套Python&Java双语代码&#xff0c; 2024.03.15 可通过leetcode所有测试用例。 目录 33. 搜索旋转排序数组…

SpringController返回值和异常自动包装

今天遇到一个需求&#xff0c;在不改动原系统代码的情况下。将Controller的返回值和异常包装到一个统一的返回对象中去。 例如原系统的接口 public String myIp(ApiIgnore HttpServletRequest request);返回的只是一个IP字符串"0:0:0:0:0:0:0:1"&#xff0c;目前接口…

一款比 K8S 更好用的编排工具——Nomod

今天给笔友们推荐一款最近发现的服务编排工具Nomad。综合感觉就是功能很强大&#xff0c;姿势很优雅&#xff0c;相比 K8S 更加轻量级&#xff0c;相比 Docker-Compose 能轻松支持分布式。 Nomad 能做什么&#xff1f; Nomad 采用统一的工作流程&#xff0c;既可以轻松部署和管…

20 OpenCV像素重映

文章目录 像素重映remap 重映算子代码示例 像素重映 简单点说就是把输入图像中各个像素按照一定的规则映射到另外一张图像的对应位置上去&#xff0c;形成一张新的图像。 g(x,y)是重映射之后的图像&#xff0c;h(x,y)是功能函数&#xff0c;f是源图像 remap 重映算子 Remap…

高效备考2025年AMC8竞赛:吃透2000-2024年600道真题(免费送题)

我们继续来随机看五道AMC8的真题和解析&#xff0c;根据实践经验&#xff0c;对于想了解或者加AMC8美国数学竞赛的考生来说&#xff0c;吃透AMC8历年真题是备考更加科学、有效的方法之一。 即使不参加AMC8竞赛&#xff0c;吃透了历年真题600道和背后的知识体系&#xff0c;那么…

阳光保险MySQL数据库平稳迁移OceanBase,稳定运营超700天

作者简介&#xff1a; 车东兴&#xff1a;于阳光保险就职&#xff0c;深耕保险行业的 IT 领域长达12 年&#xff0c;对保险领域的基础架构实践有深刻的理解与掌握。熟悉多款数据库&#xff0c;具有丰富的数据库运维经验。 王华城&#xff1a;于阳光保险就职&#xff0c;10多年一…

线性表——单链表的增删查改

本节复习链表的增删查改 首先&#xff0c; 链表不是连续的&#xff0c; 而是通过指针联系起来的。 如图&#xff1a; 这四个节点不是连续的内存空间&#xff0c; 但是彼此之间使用了一个指针来连接。 这就是链表。 现在我们来实现链表的增删查改。 目录 单链表的全部接口…

Swift:.ignoresSafeArea():自由布局的全方位掌握

ignoresSafeArea(_ regions : edges:)修饰符的说明 SwiftUI布局系统会调整视图的尺寸和位置&#xff0c;以避免特定的安全区域。这就确保了系统内容&#xff08;比如软件键盘&#xff09;或设备边缘不会遮挡您的视图。要将您的内容扩展到这些区域&#xff0c;您可以通过应用该修…

Python - 应用篇 :ChatGPT +Pycharm 序列号自动生成

前言&#xff1a; 客户要求在产品外壳上新增可追溯的二维码贴花&#xff0c;二维码信息内容如下&#xff1a; 编码格式&#xff1a;SBD 零部件代码 控制盒序列号 控制盒厂家 例如&#xff1a;[)>06P725-18428S24031410001ZJL SBD 零部件代码&#xff1a;[)>06P725-184…