网络字节转换inet_aton inet_ntoa inet_addr和inet_pton

2024-05-30 16:32

本文主要是介绍网络字节转换inet_aton inet_ntoa inet_addr和inet_pton,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


网络字节转换inet_aton & inet_ntoa & inet_addr和inet_pton

分类: LINUX

inet_aton,inet_addr inet_ntoa 在点分十进制数串(如, “192.168.1.10") 与他的 32 位网络字节二进制值之前转换 IPV4 地址,有 2 个比较新的函数 inet_pton inet_ntop ,这 2 个对 IPV4 IPV6 地址都能处理
       #include <sys/socket.h>
       #include <netinet/in.h>
       #include <arpa/inet.h>
       int inet_aton(const char *cp, struct in_addr *inp);
       in_addr_t inet_addr(const char *cp);
       char *inet_ntoa(struct in_addr in);
       inet_aton() converts the Internet host address cp from the standard numbers-and-dots notation into binary data and stores it in the struc
ture that inp points to. inet_aton() returns non-zero if the address is valid, zero if not.

inet_aton()
转换网络主机地址 cp 为二进制数值,并存储在 struct in_addr 结构中,即第二个参数 *inp, 函数返回非 0 表示 cp 主机有地有效,返回 0 表示主机地址无效。

The inet_addr() function converts the Internet host address cp from numbers-and-dots notation into binary data in network byte order.   If the input is invalid, INADDR_NONE (usually -1) is returned. This is an
 obsolete interface to inet_aton(), described immediately above; it is obsolete   because   -1 is a valid address (255.255.255.255), and inet_aton() provides a cleaner way to indicate error return.
inet_addr
函数转换网络主机地址(如 192.168.1.10) 为网络字节序二进制值,如果参数 char *cp 无效,函数返回 -1(INADDR_NONE), 这个函数在处理地址为 255.255.255.255 时也返回 1,255.255.255.255 是一个有效的地址,不过 inet_addr 无法处理 ;

The inet_ntoa() function converts the Internet host address in given in network byte order to a string in standard numbers-and-dots notation. The string is returned in a statically allocated buffer, which subse
quent calls will overwrite.
inet_ntoa
函数转换网络字节排序的地址为标准的 ASCII 以点分开的地址 ,, 该函数返回指向点分开的字符串地址的指针,该字符串的空间为静态分配的,这意味着在第二次调用该函数时,上一次调用将会被重写(复盖),所以如果需要保存该串最后复制出来自己管理!

现在一般使用 inet_aton inet_ntoa 来处理网络字节和主机字节之间的转换 ;

有两个更新的函数 inet_pton inet_ntop 2 个函数能够处理 ipv4 ipv6, 原型如下
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
int inet_pton(int af, const char *src, void *dst);

这个函数转换字符串到网络地址,第一个参数 af 是地址族,转换后存在 dst
inet_pton
inet_addr 的扩展,支持的多地址族有下列:

AF_INET
       src
为指向字符型的地址,即 ASCII 的地址的首地址( ddd.ddd.ddd.ddd 格式的),函数将该地址
      
转换为 in_addr 的结构体,并复制在 *dst

AF_INET6
       src
为指向 IPV6 的地址,,函数将该地址
      
转换为 in6_addr 的结构体,并复制在 *dst
如果函数出错将返回一个负值,并将 errno 设置为 EAFNOSUPPORT ,如果参数 af 指定的地址族和 src 格式不对,函数将返回 0

函数 inet_ntop 进行相反的转换原型如下
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt);
这个函数转换网络二进制结构到 ASCII 类型的地址,参数的作用和上面相同,只是多了一个参数 socklen_t cnt, 他是所指向缓存区 dst 的大小,避免溢出,如果缓存区太小无法存储地址的值,则返回一个空指针,并将 errno 置为 ENOSPC

例子:
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>

int main(void)
{
    char* ip = "192.168.1.87";
    struct in_addr inp;
    u_int32_t addr = 0x5701a8c0;
    inet_aton(ip, &inp);
    printf("%x ", inp);
    inp.s_addr = addr;
    printf("%s \n", inet_ntoa(inp));
    return 0;
}

这篇关于网络字节转换inet_aton inet_ntoa inet_addr和inet_pton的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016526

相关文章

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络

配置InfiniBand (IB) 和 RDMA over Converged Ethernet (RoCE) 网络 服务器端配置 在服务器端,你需要确保安装了必要的驱动程序和软件包,并且正确配置了网络接口。 安装 OFED 首先,安装 Open Fabrics Enterprise Distribution (OFED),它包含了 InfiniBand 所需的驱动程序和库。 sudo

【机器学习】高斯网络的基本概念和应用领域

引言 高斯网络(Gaussian Network)通常指的是一个概率图模型,其中所有的随机变量(或节点)都遵循高斯分布 文章目录 引言一、高斯网络(Gaussian Network)1.1 高斯过程(Gaussian Process)1.2 高斯混合模型(Gaussian Mixture Model)1.3 应用1.4 总结 二、高斯网络的应用2.1 机器学习2.2 统计学2.3

网络学习-eNSP配置NAT

NAT实现内网和外网互通 #给路由器接口设置IP地址模拟实验环境<Huawei>system-viewEnter system view, return user view with Ctrl+Z.[Huawei]undo info-center enableInfo: Information center is disabled.[Huawei]interface gigabit

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的