套接字編程基本的數據結構struct sockaddr_in, struct sockaddr,struct in_addr

一、結構體 struct sockaddr_in,  struct sockaddr,  struct in_addr

struct sockaddr_in,  struct sockaddr,struct in_addr,這是網絡編程中常用的結構體,每次都記不住它們各自的成員是啥,需要臨時查,爲方便以後的查看,在這裏總結下。

struct sockaddr {
unsigned short sa_family;  /* 地址族, AF_xxx */
char sa_data[14];  /* 14字節的協議地址*/
};

上面是通用的socket地址,具體到Internet socket,用下面的結構,二者可以進行類型轉換
struct sockaddr_in {
short int sin_family; /* 地址族 */
unsigned short int sin_port; /* 端口號 */
struct in_addr sin_addr; /* Internet地址 */
unsigned char sin_zero[8]; /* 與struct sockaddr一樣的長度 */
};

struct in_addr就是32位IP地址。
struct in_addr {
unsigned long s_addr;
};

也有
struct in_addr {
union {
struct { u_char s_b1,s_b2,s_b3,s_b4;} S_un_b;
struct { u_short s_w1,s_w2;} S_un_w;
u_long S_addr;
} S_un;
};
利用u_long htonl(u_long hostlong);將主機字節序轉換爲TCP/IP網絡字節序.
利用u_short htons(u_short hostshort);將主機字節序轉換爲TCP/IP網絡字節序.

inet_addr()是將一個點分制的IP地址(如192.168.0.1)轉換爲上述結構中需要的32位IP地址(0xC0A80001)。

通常的用法是:
int sockfd;
struct sockaddr_in my_addr;
sockfd = socket(AF_INET, SOCK_STREAM, 0); /* 做一些錯誤檢查! */

my_addr.sin_family = AF_INET; /* 主機字節序 */
my_addr.sin_port = htons(MYPORT); /* short, 網絡字節序 */
my_addr.sin_addr.s_addr = inet_addr(“192.168.0.1″);

bzero(&(my_addr.sin_zero), 8); /* zero the rest of the struct */
/* 不要忘了爲bind()做錯誤檢查: */
bind(sockfd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr));

二、inet_addr、 inet_aton、inet_ntoa

inet_addr:  將網絡地址轉爲網絡二進制數字,返回的IP地址是網絡序的。函數原型: unsigned long in inet_addr(const char *cp)

inet_aton:將網絡地址轉爲網絡二進制數字,與inet_addr的區別是,結果不是作爲返回值,而是保存形參inp所指的in_addr結構體中。函數原型:int inet_aton(cont char* cp, struct in_addr *inp)

inet_ntoa:將網絡二進制數字轉爲網絡地址,函數原型是: char *inet_ntoa(struct in_addr in)

、 有兩個更新的函數inet_pton和inet_ntop,這2個函數能夠處理ipv4和ipv6,原型如下

int inet_pton(int af, const char *src, void *dst);
這個函數轉換字符串到網絡地址,第一個參數af是地址族,轉換後存在dst中

inet_pton 是inet_addr的擴展,支持的多地址族有下列:

AF_INET:src爲指向字符型的地址,即ASCII的地址的首地址(ddd.ddd.ddd.ddd格式的),函數將該地址轉換爲in_addr的結構體,並複製在*dst中

AF_INET6:rc爲指向IPV6的地址,,函數將該地址轉換爲in6_addr的結構體,並複製在*dst中

如果函數出錯將返回一個負值,並將errno設置爲EAFNOSUPPORT,如果參數af指定的地址族和src格式不對,函數將返回0。

 

函數inet_ntop進行相反的轉換原型如下
const char *inet_ntop(int af, const void *src, char *dst, socklen_t cnt);
這個函數轉換網絡二進制結構到ASCII類型的地址,參數的作用和上面相同,只是多了一個參數socklen_t cnt,他是所指向緩存區dst的大小,避免溢出,如果緩存區太小無法存儲地址的值,則返回一個空指針,並將errno置爲ENOSPC

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章