iOS开发:获取iPhone的IP地址 - Inzaghi-iOS开发博客,互联网资讯,米兰新闻

iOS开发:获取iPhone的IP地址

 

定义了几个方法,获取iphone的IP地址。

IPAdress.h

 

  1. #define MAXADDRS    32
  2. extern char *if_names[MAXADDRS];
  3. extern char *ip_names[MAXADDRS];
  4. extern char *hw_addrs[MAXADDRS];
  5. extern unsigned long ip_addrs[MAXADDRS];
  6. // Function prototypes
  7. void InitAddresses();
  8. void FreeAddresses();
  9. void GetIPAddresses();
  10. void GetHWAddresses();

 

 

IPAddress.c

 

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #include <unistd.h>
  5. #include <sys/ioctl.h>
  6. #include <sys/types.h>
  7. #include <sys/socket.h>
  8. #include <netinet/in.h>
  9. #include <netdb.h>
  10. #include <arpa/inet.h>
  11. #include <sys/sockio.h>
  12. #include <net/if.h>
  13. #include <errno.h>
  14. #include <net/if_dl.h>
  15. #include “GetAddresses.h”
  16. #define min(a,b)    ((a) < (b) ? (a) : (b))
  17. #define max(a,b)    ((a) > (b) ? (a) : (b))
  18. #define BUFFERSIZE  4000
  19. char *if_names[MAXADDRS];
  20. char *ip_names[MAXADDRS];
  21. char *hw_addrs[MAXADDRS];
  22. unsigned long ip_addrs[MAXADDRS];
  23. static int   nextAddr = 0;
  24. void InitAddresses()
  25. {
  26.     int i;
  27.     for (i=0; i<MAXADDRS; ++i)
  28.     {
  29.         if_names[i] = ip_names[i] = hw_addrs[i] = NULL;
  30.         ip_addrs[i] = 0;
  31.     }
  32. }
  33. void FreeAddresses()
  34. {
  35.     int i;
  36.     for (i=0; i<MAXADDRS; ++i)
  37.     {
  38.         if (if_names[i] != 0) free(if_names[i]);
  39.         if (ip_names[i] != 0) free(ip_names[i]);
  40.         if (hw_addrs[i] != 0) free(hw_addrs[i]);
  41.         ip_addrs[i] = 0;
  42.     }
  43.     InitAddresses();
  44. }
  45. void GetIPAddresses()
  46. {
  47.     int                 i, len, flags;
  48.     char                buffer[BUFFERSIZE], *ptr, lastname[IFNAMSIZ], *cptr;
  49.     struct ifconf       ifc;
  50.     struct ifreq        *ifr, ifrcopy;
  51.     struct sockaddr_in  *sin;
  52.     char temp[80];
  53.     int sockfd;
  54.     for (i=0; i<MAXADDRS; ++i)
  55.     {
  56.         if_names[i] = ip_names[i] = NULL;
  57.         ip_addrs[i] = 0;
  58.     }
  59.     sockfd = socket(AF_INET, SOCK_DGRAM, 0);
  60.     if (sockfd < 0)
  61.     {
  62.         perror(“socket failed”);
  63.         return;
  64.     }
  65.     ifc.ifc_len = BUFFERSIZE;
  66.     ifc.ifc_buf = buffer;
  67.     if (ioctl(sockfd, SIOCGIFCONF, &ifc) < 0)
  68.     {
  69.         perror(“ioctl error”);
  70.         return;
  71.     }
  72.     lastname[0] = 0;
  73.     for (ptr = buffer; ptr < buffer + ifc.ifc_len; )
  74.     {
  75.         ifr = (struct ifreq *)ptr;
  76.         len = max(sizeof(struct sockaddr), ifr->ifr_addr.sa_len);
  77.         ptr += sizeof(ifr->ifr_name) + len;  // for next one in buffer
  78.         if (ifr->ifr_addr.sa_family != AF_INET)
  79.         {
  80.             continue;   // ignore if not desired address family
  81.         }
  82.         if ((cptr = (char *)strchr(ifr->ifr_name, ‘:’)) != NULL)
  83.         {
  84.             *cptr = 0;      // replace colon will null
  85.         }
  86.         if (strncmp(lastname, ifr->ifr_name, IFNAMSIZ) == 0)
  87.         {
  88.             continue;   /* already processed this interface */
  89.         }
  90.         memcpy(lastname, ifr->ifr_name, IFNAMSIZ);
  91.         ifrcopy = *ifr;
  92.         ioctl(sockfd, SIOCGIFFLAGS, &ifrcopy);
  93.         flags = ifrcopy.ifr_flags;
  94.         if ((flags & IFF_UP) == 0)
  95.         {
  96.             continue;   // ignore if interface not up
  97.         }
  98.         if_names[nextAddr] = (char *)malloc(strlen(ifr->ifr_name)+1);
  99.         if (if_names[nextAddr] == NULL)
  100.         {
  101.             return;
  102.         }
  103.         strcpy(if_names[nextAddr], ifr->ifr_name);
  104.         sin = (struct sockaddr_in *)&ifr->ifr_addr;
  105.         strcpy(temp, inet_ntoa(sin->sin_addr));
  106.         ip_names[nextAddr] = (char *)malloc(strlen(temp)+1);
  107.         if (ip_names[nextAddr] == NULL)
  108.         {
  109.             return;
  110.         }
  111.         strcpy(ip_names[nextAddr], temp);
  112.         ip_addrs[nextAddr] = sin->sin_addr.s_addr;
  113.         ++nextAddr;
  114.     }
  115.     close(sockfd);
  116. }
  117. void GetHWAddresses()
  118. {
  119.    struct ifconf ifc;
  120.    struct ifreq *ifr;
  121.    int i, sockfd;
  122.    char buffer[BUFFERSIZE], *cp, *cplim;
  123.    char temp[80];
  124.    for (i=0; i<MAXADDRS; ++i)
  125.    {
  126.       hw_addrs[i] = NULL;
  127.    }
  128.    sockfd = socket(AF_INET, SOCK_DGRAM, 0);
  129.    if (sockfd < 0)
  130.    {
  131.       perror(“socket failed”);
  132.       return;
  133.    }
  134.    ifc.ifc_len = BUFFERSIZE;
  135.    ifc.ifc_buf = buffer;
  136.    if (ioctl(sockfd, SIOCGIFCONF, (char *)&ifc) < 0)
  137.    {
  138.       perror(“ioctl error”);
  139.       close(sockfd);
  140.       return;
  141.    }
  142.    ifr = ifc.ifc_req;
  143.    cplim = buffer + ifc.ifc_len;
  144.    for (cp=buffer; cp < cplim; )
  145.    {
  146.       ifr = (struct ifreq *)cp;
  147.       if (ifr->ifr_addr.sa_family == AF_LINK)
  148.       {
  149.          struct sockaddr_dl *sdl = (struct sockaddr_dl *)&ifr->ifr_addr;
  150.          int a,b,c,d,e,f;
  151.          int i;
  152.          strcpy(temp, (char *)ether_ntoa(LLADDR(sdl)));
  153.          sscanf(temp, “%x:%x:%x:%x:%x:%x”, &a, &b, &c, &d, &e, &f);
  154.          sprintf(temp, “%02X:%02X:%02X:%02X:%02X:%02X”,a,b,c,d,e,f);
  155.          for (i=0; i<MAXADDRS; ++i)
  156.          {
  157.             if ((if_names[i] != NULL) && (strcmp(ifr->ifr_name, if_names[i]) == 0))
  158.             {
  159.                if (hw_addrs[i] == NULL)
  160.                {
  161.                   hw_addrs[i] = (char *)malloc(strlen(temp)+1);
  162.                   strcpy(hw_addrs[i], temp);
  163.                   break;
  164.                }
  165.             }
  166.         }
  167.       }
  168.       cp += sizeof(ifr->ifr_name) + max(sizeof(ifr->ifr_addr), ifr->ifr_addr.sa_len);
  169.    }
  170.    close(sockfd);
  171. }

 

 

 

如何用呢, 我们在MyAppAppDelegate.h中如下

 

  1. #import <UIKit/UIKit.h>
  2. @interface MyAppAppDelegate : NSObject <UIApplicationDelegate> {
  3.     NSString *localIP;
  4. }
  5. @property (nonatomic, retain) NSString *localIP;
  6. – (NSString *)deviceIPAdress;
  7. @end

 

 

 

MyAppDelegate.m

 

  1. – (void)applicationDidFinishLaunching:(UIApplication *)application {
  2.     self.localIP = [self deviceIPAdress];
  3.         …
  4. }
  5. – (NSString *)deviceIPAdress {
  6.     InitAddresses();
  7.     GetIPAddresses();
  8.     GetHWAddresses();
  9.         /*
  10.     int i;
  11.     NSString *deviceIP;
  12.     for (i=0; i<MAXADDRS; ++i)
  13.     {
  14.         static unsigned long localHost = 0x7F000001;        // 127.0.0.1
  15.         unsigned long theAddr;
  16.         theAddr = ip_addrs[i];
  17.         if (theAddr == 0) break;
  18.         if (theAddr == localHost) continue;
  19.         NSLog(@”%s %s %s/n”, if_names[i], hw_addrs[i], ip_names[i]);
  20.     }
  21.     deviceIP = [NSString stringWithFormat:@”%s”, ip_names[i]];
  22.     */
  23.         //this will get you the right IP from your device in format like 198.111.222.444. If you use the for loop above you will se that ip_names array will also contain localhost IP 127.0.0.1 that’s why I don’t use it. Eventualy this was code from mac that’s why it uses arrays for ip_names as macs can have multiple IPs
  24.     return [NSString stringWithFormat:@”%s”, ip_names[1]];
  25. }

 

 

标签:
,,
分类:iOS开发 | 发布:inzaghi | 评论:0 条 | 发表时间:2014-01-12 21:34
引用:点击这里获取该日志的TrackBack引用地址
上一篇:
下一篇:

发表评论

*

* 绝不会泄露


Design By Inzaghi | 京ICP备16047555号-1