喜欢FreeBSD

在FreeBSD中记下的

  山阳博客 :: 联系 :: 聚合  :: 登录
  73 Posts :: 0 Stories :: 7 Comments :: 0 Trackbacks

留言簿(0)

搜索

  •  

最新评论

阅读排行榜

评论排行榜

2008年7月22日 #

 
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));
 
 
 
posted @ 2008-07-22 01:47 hihee的博客 阅读(101) | 评论 (0)编辑 收藏

inet_addr函数处理IP地址需要注意的问题
xuefeifei 发表于 2006-3-28 15:39:00
 
现在我们很幸运,因为我们有很多的函数来方便地操作 IP 地址。
没有 必要用手工计算它们,也没有必要用"<<"操作来储存成长整字型。
首先,假设你已经有了一个sockaddr_in结构体ina,你有一个IP地址"132.241.5.10" 要储存在其中,
你就要用到函数inet_addr(),将IP地址从 点数格式转换成无符号长整型。使用方法如下:
      ina.sin_addr.s_addr = inet_addr("132.241.5.10");
注意,inet_addr()返回的地址已经是网络字节格式,所以你无需再调用 函数htonl()。
我们现在发现上面的代码片断不是十分完整的,因为它没有错误检查。
显而易见,当inet_addr()发生错误时返回-1。记住这些二进制数字?(无符 号数)-1仅仅和IP地址255.255.255.255相符合!
这可是广播地址!大错特 错!记住要先进行错误检查。
好了,现在你可以将IP地址转换成长整型了。有没有其相反的方法呢? 它可以将一个in_addr结构体输出成点数格式?这样的话,你就要用到函数 inet_ntoa()("ntoa"的含义是"network to ascii"),就像这样:
printf("%s",inet_ntoa(ina.sin_addr));
它将输出IP地址。需要注意的是inet_ntoa()将结构体in-addr作为一 个参数,不是长整形。
同样需要注意的是它返回的是一个指向一个字符的 指针。它是一个由inet_ntoa()控制的静态的固定的指针,
所以每次调用 inet_ntoa(),它就将覆盖上次调用时所得的IP地址。例如:
     
       char *a1, *a2;
      a1 = inet_ntoa(ina1.sin_addr); /* 这是198.92.129.1 */
      a2 = inet_ntoa(ina2.sin_addr); /* 这是132.241.5.10 */
      printf("address 1: %s ",a1);
      printf("address 2: %s ",a2);
输出如下:
      address 1: 132.241.5.10
      address 2: 132.241.5.10
假如你需要保存这个IP地址,使用strcopy()函数来指向你自己的字符指针。
 
posted @ 2008-07-22 01:41 hihee的博客 阅读(129) | 评论 (0)编辑 收藏