inet_pton
NAME
inet_pton - 將 IPv4 和 IPv6 地址從點分十進制轉換為二進制
SYNOPSIS
#include <arpa/inet.h>
int inet_pton(int af, const char *src, void *dst);
DESCRIPTION
該函數將字符串src
轉換為af
地址類型協議簇的網絡地址,並存儲到dst
中。對於af
參數,必須為AF_INET
或AF_INET6
RETURN VALUE
inet_pton
轉換成功則返回1,對於指定的地址類型協議簇,如果不是一個有效的網絡地址,將轉換失敗,返回 0,如果指定的地址類型協議簇不合法,將返回-1並,並且errno
設置為EAFNOSUPPORT
NOTES
不同於inet_aton
和inet——addr
,inept_pton
支持 IPv6 地址。另一方面,inet_pton
僅支持點分十進制表示的 IPv4 地址,而inet_aton
和inet_addr
接受更通用的數字和點表示法(十六進制和八進制數字格式,以及格式不需要顯式寫入所有四個字節)。
inet_ntop
NAME
inet_ntop - 將 IPv4 和 IPv6 地址從二進制轉換為點分十進制
SYNOPSIS
#include <arpa/inet.h>
const char *inet_ntop(int af, const void *src, char *dst, socklen_t size);
DESCRIPTION
該函數將地址類型協議簇為af
的網絡地址src
轉換為字符串,並將其存儲到dst
中,其中dst
不能是空指針。調用者在參數size
中指定可使用的緩沖字節數。
inet_ntop
拓展自inet_ntoa
來支持多種地址類型協議簇,inet_ntoa
現在已經被棄用。
RETURN VALUE
inet_ntop
執行成功,返回一個指向dst
的非空指針,如果執行失敗,將返回NULL
,並且errno
設置為相應的錯誤類型。
ERRORS
- EAFNOSUPPORT
af
並不是一個合法的地址類型協議簇 - ENOSPC
要轉換的字符串地址src
其字節大小超過了給定的緩沖字節大小
EXAMPLE
以下是關於inet_pton
和inet_ntop
函數使用的例子
#include <arpa/inet.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{
unsigned char buf[sizeof(struct in6_addr)];
int domain, s;
char str[INET6_ADDRSTRLEN];
if (argc != 3) {
fprintf(stderr, "Usage: %s {i4|i6|<num>} string\n", argv[0]);
exit(EXIT_FAILURE);
}
domain = (strcmp(argv[1], "i4") == 0) ? AF_INET :
(strcmp(argv[1], "i6") == 0) ? AF_INET6 : atoi(argv[1]);
s = inet_pton(domain, argv[2], buf);
if (s <= 0) {
if (s == 0)
fprintf(stderr, "Not in presentation format");
else
perror("inet_pton");
exit(EXIT_FAILURE);
}
if (inet_ntop(domain, buf, str, INET6_ADDRSTRLEN) == NULL) {
perror("inet_ntop");
exit(EXIT_FAILURE);
}
printf("%s\n", str);
exit(EXIT_SUCCESS);
}
inet_aton inet_addr inet_ntoa
NAME
inet_aton, inet_addr, inet_ntoa - 網絡地址操作例程
SYNOPSIS
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
typedef uint32_t in_addr_t;
struct in_addr{
in_addr_t s_addr;
};
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);
DESCRIPTION
inet_aton
函數將網絡主機地址cp
從 IPv4 的點分十格式轉換為二進制值(以網絡字節序)並且把它保存在inp
指針指向的結構體中。如果地址是合法的,那么inet_aton
函數返回非0值,反之返回0值。cp
中提供的地址可以要有以下幾種格式:
- a.b.c.d 四個數字部分中的每一個指定地址的一個字節,字節按從左到右的順序分配以產生二進制地址。
- a.b.c a和b指定二進制地址的前兩個字節,c被解釋為16位值,它定義二進制地址的最右邊兩個字節。此表示法適用於指定(過時的)B類網絡地址。
- a.b a指定二進制地址的第一個字節,b被解釋為24位值,它定義了二進制地址的最右邊三個字節。此表示法適用於指定(過時的)A類網絡地址。
- a a被解釋為32位值,直接存儲到二進制地址中而不進行任何字節重新排列。
在所有上述形式中,虛線標示的地址格式可以用十進制,八進制(帶前導0)或十六進制指定(前導0X)。任何這些形式的地址統稱為IPV4數字和點符號。使用正好四個十進制數稱為 IPv4 點分十進制表示法。
如果提供的字符串地址被成功轉換,inet_aton
函數返回1,如果提供的字符串地址不合法,返回0(此時errno
不會被設置為錯誤)
inet_addr
函數將網絡主機地址cp
從 IPv4 的數字點表示形式轉換為以網絡字節順序的二進制形式。如果輸入不合法,INADDR_NONE
(通常為-1)被返回。這個函數存在一個問題,因為-1是一個合法的地址(255.255.255.255)。可以使用inet_aton
函數、inet_pton
函數或者getaddrinfo
函數來代替使用它,這些函數提供了一種更清晰的方式來指示錯誤返回。
inet_ntoa
函數將網絡主機地址in
轉換為點分十格式的 IPv4 地址。該函數的返回值所指向的字符串駐留在靜態內存中,后續調用將覆蓋該緩沖區。
NOTES
在 x86 架構中,主機字節順序首先是最低有效字節(小端),而在因特網上使用的網絡字節順序是最高有效字節(大端)。
EXAMPLE
#include <arpa/inet.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[])
{
unsigned char buf[sizeof(struct in6_addr)];
int domain, s;
char str[INET6_ADDRSTRLEN];
if (argc != 3) {
fprintf(stderr, "Usage: %s {i4|i6|<num>} string\n", argv[0]);
exit(EXIT_FAILURE);
}
domain = (strcmp(argv[1], "i4") == 0) ? AF_INET :
(strcmp(argv[1], "i6") == 0) ? AF_INET6 : atoi(argv[1]);
s = inet_pton(domain, argv[2], buf);
if (s <= 0) {
if (s == 0)
fprintf(stderr, "Not in presentation format");
else
perror("inet_pton");
exit(EXIT_FAILURE);
}
if (inet_ntop(domain, buf, str, INET6_ADDRSTRLEN) == NULL) {
perror("inet_ntop");
exit(EXIT_FAILURE);
}
printf("%s\n", str);
exit(EXIT_SUCCESS);
}