1. inet_aton()是一個改進的方法來將一個字符串IP地址轉換為一個32位的網絡序列IP地址。 2. inet_ntoa() 本函數將一個用in參數所表示的Internet地址結構轉換成以“.” 間隔的諸如“a.b.c.d”的字符串形式。 若無錯誤發生,inet_ntoa()返回一個字符指針。否則的話,返回NVLL。 3. in_addr_t inet_addr(const char *cp); 成功:返回成功轉換的ip地址,輸入字符串有效 返回0:輸入字符串有錯,返回-1。 所在頭文件:<arpa/inet.h> 若無錯誤發生,inet_addr()返回一個無符號長整型數,其中以適當字節順序存放Internet地址。如果傳入的字符串不是一個合法的Internet地址,如“a.b.c.d”地址中任一項超過255,那么inet_addr()返回INADDR_NONE。在IP只有一部分時(即沒有 ”.“ 時),IP的字符串如果只由數字組成,inet_addr()不檢查數字是否大於255 函數概要如下: 頭文件:#include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> 完整描述: int inet_aton(const char *string, struct in_addr*addr); 參數描述: 1 輸入參數string包含ASCII表示的IP地址。 2 輸出參數addr是將要用新的IP地址更新的結構。 返回值: 如果這個函數成功,函數的返回值非零,如果輸入地址不正確則會返回零。使用這個函數並沒有錯誤碼存放在errno中,所以他的值會被忽略。 函數說明及舉例: 對於這個函數有一點迷惑的就是這個函數調用所需要的兩個參數。 如果我們定義了一個AF_INET套接口地址: struct sockaddr_in adr_inet; /* AF_INET */ 提供給inet_aton函數調用的參數指針為 &adr_inet.sin_addr 下面這個程序使用inet_aton函數,而不是我們在前面所談到的in_addr函數。 /* * inetaton.c static void bail(const char *on_what) { fputs(on_what,stderr); fputs("\n",stderr); } int main(int argc,char **argv) { int z; struct sockaddr_in adr_inet; /* AF_INET */ int len_inet; /* length */ int sck_inet; /* Socket */ /* Create a Socket */ sck_inet = socket(AF_INET,SOCK_STREAM,0); if(sck_inet == -1) bail("Socket()"); /* Establish address */ memset(&adr_inet,0,sizeof adr_inet); adr_inet.sin_family = AF_INET; adr_inet.sin_port = htons(9000); . if( !inet_aton("127.0.0.1",&adr_inet.sin_addr)) bail("bad address"); len_inet = sizeof adr_inet; /* Bind it to the socket */ z = bind(sck_inet,(struct sockaddr *)&adr_inet,len_inet); if(z == -1) bail("bind()"); /* Display our socket address */ system("netstat -pa --tcp 2>/dev/null" " | grep inetaton"); return 0; } 程序的運行結果如下: S$ ./inetaton tcp 0 0 127.0.0.23:9000 *:* CLOSE 1007/inetaton
