inet_pton、inet_ntop函数

来源:互联网 发布:java架构师 在线课 编辑:程序博客网 时间:2024/06/09 19:56

inet_pton和inet_ntop函数 
这两个函数是随IPv6出现的函数,对于IPv4地址和IPv6地址都适用,函数中p和n分别代表表达(presentation)和数值(numeric)。地址的表达格式通常是ASCII字符串,数值格式则是存放到套接字地址结构的二进制值。

#include <arpe/inet.h>int inet_pton(int family, const char *strptr, void *addrptr);        返回值:若成功则为1,若输入不是有效的表达式则为0,若出错则为-1const char * inet_ntop(int family, const void *addrptr, char *strptr, size_t len);        返回值:若成功则为指向结构的指针,若出错则为NULL
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

这两个函数的family参数既可以是AF_INET也可以是AF_INET6。如果,以不被支持的地址族作为family参数,这两个函数都返回一个错误,并将errno置为EAFNOSUPPORT. 
第一个函数尝试转换由strptr指针所指向的字符串,并通过addrptr指针存放二进制结果,若成功则返回值为1,否则如果所指定的family而言输入字符串不是有效的表达式格式,那么返回值为0. 
inet_ntop进行相反的转换,从数值格式(addrptr)转换到表达式(strptr)。len参数是目标存储单元的大小,以免该函数溢出其调用者的缓冲区。为有助于指定这个大小,在

#define INET_ADDRSTRLEN 16#define INET6_ADDRSTRLEN 46
  • 1
  • 2
  • 1
  • 2

如果len太小,不足以容纳表达式结果,那么返回一个空指针,并置为errno为ENOSPC。 
inet_ntop函数的strptr参数不可以是一个空指针。调用者必须为目标存储单元分配内存并指定其大小,调用成功时,这个指针就是该函数的返回值。 
示例:

inet_pton(AF_INET, cp, &foo.sin_addr);代替代码foo.sin_addr.s_addr = inet_addr(cp);再用代码char str[INET_ADDRSTRLEN];ptr = inet_ntop(AF_INET,&foo.sin_addr, str, sizeof(str));代替代码ptr = inet_ntoa(foo.sin_addr);
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

下面给出了IPv4对inet_pton函数的简单定义:

int inet_pton(int family, const char *strptr, void *addrptr){    if(family == AF_INET){        struct in_addr in_val;        if(inet_aton(strptr, &in_val){            memcpy(addrptr, &in_val, sizeof(struct in_addr));            return 1;        }        return 0;    }    errno = EAFNOSUPORT;    return -1;}const char *inet_ntop(int family, const void *addrptr, char *strptr, size_t len){    const u_char *p = (const u_char *)addrptr;    if(family == AF_INET){        char temp[INET_ADDRSTRLEN];        snprintf(temp, sizeof(temp), "%d.%d.%d.%d",p[0],p[1],p[2],p[3]);        if(strlen(temp) >= len){            errno = ENOSPC;            return NULL;        }        strcpy(strptr, temp);        return strptr;    }    errno = EAFNOSUPORT;    return NULL;}