inet_ntop与inet_pton
Linux下inet_pton和inet_ntop这2个IP地址转换函数,可以在将IP地址在“点分十进制”和“整数”之间转换。而且,这2个函数能够处理ipv4和
ipv6。算是比较新的函数了。
inet_pton函数原型如下[将“点分十进制” -> “整数”]
#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 = AF_INET src为指向字符型的地址,即ASCII的地址的首地址(ddd.ddd.ddd.ddd格式的),函数将该地址
转换为in_addr的结构体,并复制在*dst中。
af =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 <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
int main (void)
{
char IPdotdec[20]; //存放点分十进制IP地址
struct in_addr s; // IPv4地址结构体
// 输入IP地址
printf("Please input IP address: ");
scanf("%s", &IPdotdec);
// 转换 inet_pton(AF_INET, IPdotdec, (void *)&s);
printf("inet_pton: 0x%x\n", s.s_addr); // 注意得到的字节序
// 反转换 inet_ntop(AF_INET, (void *)&s, IPdotdec, 16);
printf("inet_ntop: %s\n", IPdotdec); }
例程2;
#include <stdio.h> #include <stdlib.h>
#include <netinet/in.h>
int main(void)
{
char addr_p[16]; /*IP地址的点分十进制字符串表示形式*/
struct in_addr addr_n;/*IP地址的二进制表示形式*/
if(inet_pton(AF_INET,"192.168.11.6",&addr_n)<0)/*地址由字符串转换为二级制数*/
{
perror("fail to convert");
exit(1);
}
printf("address:%x\n",addr_n);/*打印地址的16进制形式*/
if(inet_ntop(AF_INET,&addr_n,addr_p,(socklen_t *)sizeof(addr_p))==NULL) /*地址由二进制数转换为点分十进制*/
{ perror("fail to convert");
exit(1);
}
printf("address:%s\n",addr_p);/*打印地址的点分十进制形式*/
return 0;
}
出错检查:
inet_pton函数成功的话返回1,参数无效返回0,错误返回-1;
inet_ntop函数成功的话返回字符串的首地址,错误返回NULL;