获取网卡的地址

//方法一

- (NSString *)currentWifiSSID {

    // Does not work on the simulator.

    NSString *ssid = nil;

    

    NSArray *ifs = (__bridge id)CNCopySupportedInterfaces();

  

    NSLog(@"ifs:%@",ifs);

    

    for (NSString *ifnam in ifs) {

        NSDictionary *info = (__bridge id)CNCopyCurrentNetworkInfo((__bridge CFStringRef)ifnam);

        NSLog(@"dici%@",[info allKeys]);

        if (info[@"BSSID"]) {

            ssid = info[@"BSSID"];

        } 

    } 

    

    return ssid; 

}


// Return the local MAC addy

// Courtesy of FreeBSD hackers email list

// Accidentally munged during previous update. Fixed thanks to mlamb.


//方法二

- (NSString *) macaddress

{

    

    int                 mib[6];

    size_t              len;

    char                *buf;

    unsigned char       *ptr;

    struct if_msghdr    *ifm;

    struct sockaddr_dl  *sdl;

    

    mib[0] = CTL_NET;

    mib[1] = AF_ROUTE;

    mib[2] = 0;

    mib[3] = AF_LINK;

    mib[4] = NET_RT_IFLIST;

    

    if ((mib[5] = if_nametoindex("en0")) == 0) {

        printf("Error: if_nametoindex error/n");

        return NULL;

    }

    

    if (sysctl(mib, 6, NULL, &len, NULL, 0) < 0) {

        printf("Error: sysctl, take 1/n");

        return NULL;

    }

    

    if ((buf = malloc(len)) == NULL) {

        printf("Could not allocate memory. error!/n");

        return NULL;

    }

    

    if (sysctl(mib, 6, buf, &len, NULL, 0) < 0) {

        printf("Error: sysctl, take 2");

        return NULL;

    }

    

    ifm = (struct if_msghdr *)buf;

    sdl = (struct sockaddr_dl *)(ifm + 1);

    ptr = (unsigned char *)LLADDR(sdl);

    NSString *outstring = [NSString stringWithFormat:@"%02x:%02x:%02x:%02x:%02x:%02x", *ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5)];

    

    //    NSString *outstring = [NSString stringWithFormat:@"%02x%02x%02x%02x%02x%02x", *ptr, *(ptr+1), *(ptr+2), *(ptr+3), *(ptr+4), *(ptr+5)];

    

    NSLog(@"outString:%@", outstring);

    

    free(buf);

    

    return [outstring uppercaseString];

}


- (NSString *)getMacAddress

{

    int                 mgmtInfoBase[6];

    char                *msgBuffer = NULL;

    size_t              length;

    unsigned char       macAddress[6];

    struct if_msghdr    *interfaceMsgStruct;

    struct sockaddr_dl  *socketStruct;

    NSString            *errorFlag = NULL;

    

    // Setup the management Information Base (mib)

    mgmtInfoBase[0] = CTL_NET;        // Request network subsystem

    mgmtInfoBase[1] = AF_ROUTE;       // Routing table info

    mgmtInfoBase[2] = 0;

    mgmtInfoBase[3] = AF_LINK;        // Request link layer information

    mgmtInfoBase[4] = NET_RT_IFLIST// Request all configured interfaces

    

    // With all configured interfaces requested, get handle index

    if ((mgmtInfoBase[5] = if_nametoindex("en0")) == 0)

        errorFlag = @"if_nametoindex failure";

    else

    {

        // Get the size of the data available (store in len)

        if (sysctl(mgmtInfoBase, 6, NULL, &length, NULL, 0) < 0)

            errorFlag = @"sysctl mgmtInfoBase failure";

        else

        {

            // Alloc memory based on above call

            if ((msgBuffer = malloc(length)) == NULL)

                errorFlag = @"buffer allocation failure";

            else

            {

                // Get system information, store in buffer

                if (sysctl(mgmtInfoBase, 6, msgBuffer, &length, NULL, 0) < 0)

                    errorFlag = @"sysctl msgBuffer failure";

            }

        }

    }

    

    // Befor going any further...

    if (errorFlag != NULL)

    {

        NSLog(@"Error: %@", errorFlag);

        return errorFlag;

    }

    

    // Map msgbuffer to interface message structure

    interfaceMsgStruct = (struct if_msghdr *) msgBuffer;

    

    // Map to link-level socket structure

    socketStruct = (struct sockaddr_dl *) (interfaceMsgStruct + 1);

    

    // Copy link layer address data in socket structure to an array

    memcpy(&macAddress, socketStruct->sdl_data + socketStruct->sdl_nlen, 6);

    

    // Read from char array into a string object, into traditional Mac address format

    NSString *macAddressString = [NSString stringWithFormat:@"%02x:%02x:%02x:%02x:%02x:%02x",

                                  macAddress[0], macAddress[1], macAddress[2],

                                  macAddress[3], macAddress[4], macAddress[5]];

    NSLog(@"Mac Address: %@", macAddressString);

    

    // Release the buffer memory

    free(msgBuffer);

    

    return macAddressString;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值