Linux网络编程--字符串IP和二进制IP转换

本文介绍了Linux网络编程中字符串IP和二进制IP的转换问题。传统函数如inet_ntoa和inet_addr存在安全隐患,如内存覆盖和错误返回值。为解决这些问题,文章推荐使用安全的、可重入的函数inet_pton和inet_ntop,这两个函数支持IPv4和IPv6,并通过代码示例展示了其用法。
摘要由CSDN通过智能技术生成

一:不安全的(不可重入性)inet_xxx()函数族

由于计算机理解的IP都是以二进制形式保存的,那么在网络程序设计中经常会需要字符串IP和二进制IP的转换,linux系统有一组要用于网络地址转换的函数,如下:

       #include <sys/socket.h>
       #include <netinet/in.h>
       #include <arpa/inet.h>

       int inet_aton(const char *cp, struct in_addr *inp);
       //将点分4段式的IP地址转换为结构in_addr值
       in_addr_t inet_addr(const char *cp);
       //将字符串转换为结构in_addr值
       in_addr_t inet_network(const char *cp); 
       //将字符串地址的网络部分转换为结构in_addr值
       char *inet_ntoa(struct in_addr in); 
       //将结构in_addr转为字符串
       struct in_addr inet_makeaddr(int net, int host); 
       //将网络地址和主机地址合成为IP地址,返回值是in_addr值
       in_addr_t inet_lnaof(struct in_addr in); 
       //获得地址的主机部分
       in_addr_t inet_netof(struct in_addr in); 
       //获得地址的网络部分

以上部分函数存在缺陷,例如:
inet_ntoa函数返回值是一个指向字符串的指针,此内存会在每次调用inet_nota函数的时候被覆盖掉,如果不及时拿走数据就会出现不可预料的错误,因此函数是不安全的,存在某种隐患;
inet_addr,inet_network函数的返回值是-1时表示错误,占用了地址255.255.255.255的值,存在缺陷,埋下了隐患。
下面用一段代码介绍使用方法和隐患的部分:

#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值