inet_pton是一個IP地址轉換函數,可以在將IP地址在“點分十進制”和“二進制整數”之間轉換,而且inet_pton和inet_ntop這2個函數能夠處理ipv4和ipv6。算是比較新的函數了。
1.把ip地址轉化為用于網絡傳輸的二進制數值
int inet_aton(const char *cp, struct in_addr *inp);
inet_aton() 轉換網絡主機地址ip(如192.168.1.10)為二進制數值,并存儲在struct in_addr結構中,即第二個參數*inp,函數返回非0表示cp主機有地有效,返回0表示主機地址無效。(這個轉換完后不能用于網絡傳輸,還需要調用htons或htonl函數才能將主機字節順序轉化為網絡字節順序)
in_addr_t inet_addr(const char *cp);
inet_addr函數轉換網絡主機地址(如192.168.1.10)為網絡字節序二進制值,如果參數char *cp無效,函數返回-1(INADDR_NONE),這個函數在處理地址為255.255.255.255時也返回-1,255.255.255.255是一個有效的地址,不過inet_addr無法處理;
2.將網絡傳輸的二進制數值轉化為成點分十進制的ip地址
char *inet_ntoa(struct in_addr in);
inet_ntoa 函數轉換網絡字節排序的地址為標準的ASCII以點分開的地址,該函數返回指向點分開的字符串地址(如192.168.1.10)的指針,該字符串的空間為靜態分配的,這意味著在第二次調用該函數時,上一次調用將會被重寫(復蓋),所以如果需要保存該串最后復制出來自己管理!
我們如何輸出一個點分十進制的IP呢?我們來看看下面的程序:
#include stdio.h>
#include sys/socket.h>
#include netinet/in.h>
#include arpa/inet.h>
#include string.h>
int main()
{
struct in_addr addr1,addr2;
ulong l1,l2;
l1= inet_addr("192.168.0.74");
l2 = inet_addr("211.100.21.179");
memcpy(addr1, l1, 4);
memcpy(addr2, l2, 4);
printf("%s : %s\n", inet_ntoa(addr1), inet_ntoa(addr2)); //注意這一句的運行結果
printf("%s\n", inet_ntoa(addr1));
printf("%s\n", inet_ntoa(addr2));
return 0;
}
實際運行結果如下:
192.168.0.74 : 192.168.0.74 //從這里可以看出,printf里的inet_ntoa只運行了一次。
192.168.0.74
211.100.21.179
inet_ntoa返回一個char *,而這個char *的空間是在inet_ntoa里面靜態分配的,所以inet_ntoa后面的調用會覆蓋上一次的調用。第一句printf的結果只能說明在printf里面的可變參數的求值是從右到左的,僅此而已。
3.新型網路地址轉化函數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); //將點分十進制的ip地址轉化為用于網絡傳輸的數值格式
返回值:若成功則為1,若輸入不是有效的表達式則為0,若出錯則為-1
const char * inet_ntop(int family, const void *addrptr, char *strptr, size_t len); //將數值格式轉化為點分十進制的ip地址格式
返回值:若成功則為指向結構的指針,若出錯則為NULL
(1)這兩個函數的family參數既可以是AF_INET(ipv4)也可以是AF_INET6(ipv6)。如果,以不被支持的地址族作為family參數,這兩個函數都返回一個錯誤,并將errno置為EAFNOSUPPORT.
(2)第一個函數嘗試轉換由strptr指針所指向的字符串,并通過addrptr指針存放二進制結果,若成功則返回值為1,否則如果所指定的family而言輸入字符串不是有效的表達式格式,那么返回值為0.
(3)inet_ntop進行相反的轉換,從數值格式(addrptr)轉換到表達式(strptr)。inet_ntop函數的strptr參數不可以是一個空指針。調用者必須為目標存儲單元分配內存并指定其大小,調用成功時,這個指針就是該函數的返回值。len參數是目標存儲單元的大小,以免該函數溢出其調用者的緩沖區。如果len太小,不足以容納表達式結果,那么返回一個空指針,并置為errno為ENOSPC。
4.示例
inet_pton(AF_INET, ip, foo.sin_addr); // 代替 foo.sin_addr.addr=inet_addr(ip);
char str[INET_ADDRSTRLEN];
char *ptr = inet_ntop(AF_INET,foo.sin_addr, str, sizeof(str)); // 代替 ptr = inet_ntoa(foo.sin_addr)
總結
以上所述是小編給大家介紹的inet_pton()和inet_ntop()函數,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!