【Linux】Linux C判断两个IPv6地址是否有包含关系

news/2025/1/31 1:11:29/

功能说明

要判断两个 IPv6 地址是否具有包含关系,包括前缀的比较,可以通过以下步骤实现:

  1. 解析 IPv6 地址和前缀:将两个 IPv6 地址和它们的前缀长度解析为二进制形式。
  2. 生成掩码:根据前缀长度生成掩码。
  3. 按位比较:使用掩码对两个 IPv6 地址进行按位与操作,判断它们是否匹配。

代码实现

#include <stdio.h>
#include <string.h>
#include <arpa/inet.h>// 判断两个 IPv6 地址是否具有包含关系(包括前缀)
int is_ipv6_prefix_contained(const char *ip1_str, int prefix1_len, const char *ip2_str, int prefix2_len) 
{struct in6_addr ip1, ip2;unsigned char mask[16] = {0};int common_prefix_len = prefix1_len < prefix2_len ? prefix1_len : prefix2_len;// 将字符串形式的 IPv6 地址转换为 in6_addr 结构if (inet_pton(AF_INET6, ip1_str, &ip1) != 1) {fprintf(stderr, "Invalid IPv6 address: %s\n", ip1_str);return -1;}if (inet_pton(AF_INET6, ip2_str, &ip2) != 1){fprintf(stderr, "Invalid IPv6 address: %s\n", ip2_str);return -1;}// 生成掩码,使用较短的公共前缀长度for (int i = 0; i < common_prefix_len / 8; i++) {mask[i] = 0xFF; // 每个完整字节设置为 0xFF}if (common_prefix_len % 8 != 0) {mask[common_prefix_len / 8] = (0xFF << (8 - (common_prefix_len % 8))) & 0xFF; // 部分字节掩码}// 比较地址和前缀for (int i = 0; i < 16; i++) {if ((ip1.s6_addr[i] & mask[i]) != (ip2.s6_addr[i] & mask[i])) {return 0; // 不包含}}return 1; // 包含
}int main() 
{const char *ip1 = "2001:db8::1";int prefix1_len = 32;const char *ip2 = "2001:db8::";int prefix2_len = 48;int result = is_ipv6_prefix_contained(ip1, prefix1_len, ip2, prefix2_len);if (result == 1) {printf("IPv6 address %s/%d is contained within %s/%d\n", ip1, prefix1_len, ip2, prefix2_len);}else if (result == 0){printf("IPv6 address %s/%d is NOT contained within %s/%d\n", ip1, prefix1_len, ip2, prefix2_len);} else{printf("An error occurred.\n");}return 0;
}

代码说明

inet_pton 函数

  • 将字符串形式的 IPv6 地址转换为 struct in6_addr 结构。
  • 如果转换失败,返回值为 0 或 -1

掩码生成

  • 根据两个前缀长度的较小值生成掩码。
  • 每个完整字节设置为 0xFF,部分字节根据前缀长度生成部分掩码。

按位比较

  • 使用掩码对两个 IPv6 地址进行按位与操作。
  • 如果结果相同,则说明一个地址的前缀包含另一个地址。

返回值

  • 返回 1 表示 IPv6 地址 ip1/prefix1_len 包含或被包含于 ip2/prefix2_len
  • 返回 0 表示两者没有包含关系。
  • 返回 -1 表示输入无效。

测试用例

测试 1:IPv6 地址包含关系

输入:

  • IPv6 地址 1:2001:db8::1/32
  • IPv6 地址 2:2001:db8::/48

输出:

IPv6 address 2001:db8::1/32 is contained within 2001:db8::/48
测试 2:IPv6 地址不包含关系

输入:

  • IPv6 地址 1:2001:db9::1/32
  • IPv6 地址 2:2001:db8::/48

输出:

IPv6 address 2001:db9::1/32 is NOT contained within 2001:db8::/48
测试 3:无效输入

输入:

  • IPv6 地址 1:invalid_ip/32
  • IPv6 地址 2:2001:db8::/48

输出:

Invalid IPv6 address: invalid_ip
An error occurred.

http://www.ppmy.cn/news/1568024.html

相关文章

豆包MarsCode 蛇年编程大作战 | 高效开发“蛇年运势预测系统”

&#x1f31f; 嗨&#xff0c;我是LucianaiB&#xff01; &#x1f30d; 总有人间一两风&#xff0c;填我十万八千梦。 &#x1f680; 路漫漫其修远兮&#xff0c;吾将上下而求索。 豆包MarsCode 蛇年编程大作战 | &#x1f40d; 蛇年运势预测 在线体验地址&#xff1a;蛇年…

PyQt 异步任务 多线程的几种方案

多线程异步线程是我们常用的&#xff0c;如我们在执行耗时操作&#xff0c;又不想卡用主程序 &#xff1b; 1. QThread from PyQt5.QtCore import QThread, pyqtSignal from PyQt5.QtWidgets import QApplication, QLabel, QVBoxLayout, QWidget, QPushButton import timecl…

Linux查看服务器的内外网地址

目录&#xff1a; 1、内网地址2、外网地址3、ping时显示地址与真实不一致 1、内网地址 ifconfig2、外网地址 curl ifconfig.me3、ping时显示地址与真实不一致 原因是dns缓存导致的&#xff0c;ping这种方法也是不准确的&#xff0c;有弊端不建议使用&#xff0c;只适用于测试…

新年快乐!!Market Moments 重磅更新!

2025 新年快乐&#xff01;在这个充满希望的新年里&#xff0c;愿大家都能心想事成&#xff0c;学业进步&#xff0c;健康快乐&#xff01; 随着新年的到来&#xff0c;Market Moments 也迎来重磅更新&#xff01; 首先&#xff0c;首页进行了改版升级&#xff0c;现在你可以在…

HTB:Cicada[RE-WriteUP]

目录 连接至HTB服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 将靶机TCP开放端口号提取并保存 使用nmap对靶机TCP开放端口进行脚本、服务扫描 使用nmap对靶机TCP开放端口进行漏洞、系统扫描 使用nmap对靶机常用UDP端口进行开放扫描 使用nmap对靶机…

【反悔堆】力扣1642. 可以到达的最远建筑

给你一个整数数组 heights &#xff0c;表示建筑物的高度。另有一些砖块 bricks 和梯子 ladders 。 你从建筑物 0 开始旅程&#xff0c;不断向后面的建筑物移动&#xff0c;期间可能会用到砖块或梯子。 当从建筑物 i 移动到建筑物 i1&#xff08;下标 从 0 开始 &#xff09;…

元素的显示与隐藏

display显示隐藏visibility显示隐藏overflow溢出显示隐藏 display属性 visibility属性 overflow溢出

神经网络|(七)概率论基础知识-贝叶斯公式

【1】引言 前序我们已经了解了一些基础知识。 古典概型&#xff1a;有限个元素参与抽样&#xff0c;每个元素被抽样的概率相等。 条件概率&#xff1a;在某条件已经达成的前提下&#xff0c;新事件发生的概率。实际计算的时候&#xff0c;应注意区分&#xff0c;如果是计算综…