29

我有一个使用 rest 与服务器通信的应用程序,我想获取 iphone 的 mac 地址或设备 ID 以进行唯一性验证,这怎么做?

4

6 回答 6

41

[[UIDevice currentDevice] uniqueIdentifier]保证对每个设备都是唯一的。

于 2009-07-10T15:37:36.600 回答
40

uniqueIdentifier(在 iOS 5.0 中已弃用。相反,创建一个特定于您的应用程序的唯一标识符。)

文档建议使用CFUUIDCreate而不是[[UIDevice currentDevice] uniqueIdentifier]

所以这里是你如何在你的应用程序中生成一个唯一的 id

CFUUIDRef uuidRef = CFUUIDCreate(kCFAllocatorDefault);
NSString *uuidString = (NSString *)CFUUIDCreateString(NULL,uuidRef);

CFRelease(uuidRef);

请注意,您必须将 uuidString 保存在用户默认值或其他位置,因为您无法再次生成相同的 uuidString。

您可以使用UIPasteboard来存储您生成的 uuid。如果应用程序将被删除并重新安装,您可以从 UIPasteboard 中读取旧的 uuid。当设备被擦除时,粘贴板将被擦除。

在 iOS 6 中,他们引入了旨在创建 UUID 字符串的NSUUID 类

他们还在 iOS 6 中添加@property(nonatomic, readonly, retain) NSUUID *identifierForVendorUIDevice

对于来自同一供应商并在同一设备上运行的应用,此属性的值相同。对于来自不同供应商的同一设备上的应用程序以及不同设备上的应用程序(无论供应商)返回不同的值。

如果应用程序在后台运行,在设备重启后用户第一次解锁设备之前,此属性的值可能为 nil。如果该值为 nil,则等待并稍后再次获取该值。

同样在 iOS 6 中,您可以使用AdSupport.framework中的 ASIdentifierManager 类。你有

@property(nonatomic, readonly) NSUUID *advertisingIdentifier

讨论 与 UIDevice 的 identifierForVendor 属性不同,向所有供应商返回相同的值。这个标识符可能会改变——例如,如果用户擦除了设备——所以你不应该缓存它。

如果应用程序在后台运行,在设备重启后用户第一次解锁设备之前,此属性的值可能为 nil。如果该值为 nil,则等待并稍后再次获取该值。

编辑:

注意advertisingIdentifier可能返回

00000000-0000-0000-0000-000000000000

因为iOS中似乎有一个错误。相关问题:advertisingIdentifier 和 identifierForVendor 返回“00000000-0000-0000-0000-000000000000”

于 2012-01-17T13:24:59.487 回答
18

对于 Mac 地址,您可以使用

#import <Foundation/Foundation.h>

@interface MacAddressHelper : NSObject

+ (NSString *)getMacAddress;

@end

实施

#import "MacAddressHelper.h"
#import <sys/socket.h>
#import <sys/sysctl.h>
#import <net/if.h>
#import <net/if_dl.h>

@implementation MacAddressHelper

+ (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;
}

@end

采用:

NSLog(@"MAC address: %@",[MacAddressHelper getMacAddress]);
于 2012-05-12T10:40:24.057 回答
5

用这个:

NSUUID *id = [[UIDevice currentDevice] identifierForVendor];
NSLog(@"ID: %@", id);
于 2013-02-14T11:05:16.190 回答
4

在 IOS 5[[UIDevice currentDevice] uniqueIdentifier]中已弃用。

最好使用-identifierForVendoror -identifierForAdvertising

在这里可以找到很多有用的信息:

iOS6 UDID - identifierForVendor 与 identifierForAdvertising 相比有什么优势?

于 2012-10-06T21:36:56.040 回答
-10

在这里,我们可以使用 Asp.net C# 代码找到 IOS 设备的 mac 地址...

.aspx.cs

-
 var UserDeviceInfo = HttpContext.Current.Request.UserAgent.ToLower(); // User's Iphone/Ipad Info.

var UserMacAdd = HttpContext.Current.Request.UserHostAddress;         // User's Iphone/Ipad Mac Address



  GetMacAddressfromIP macadd = new GetMacAddressfromIP();
        if (UserDeviceInfo.Contains("iphone;"))
        {
            // iPhone                
            Label1.Text = UserDeviceInfo;
            Label2.Text = UserMacAdd;
            string Getmac = macadd.GetMacAddress(UserMacAdd);
            Label3.Text = Getmac;
        }
        else if (UserDeviceInfo.Contains("ipad;"))
        {
            // iPad
            Label1.Text = UserDeviceInfo;
            Label2.Text = UserMacAdd;
            string Getmac = macadd.GetMacAddress(UserMacAdd);
            Label3.Text = Getmac;
        }
        else
        {
            Label1.Text = UserDeviceInfo;
            Label2.Text = UserMacAdd;
            string Getmac = macadd.GetMacAddress(UserMacAdd);
            Label3.Text = Getmac;
        }

.class 文件

public string GetMacAddress(string ipAddress)
    {
        string macAddress = string.Empty;
        if (!IsHostAccessible(ipAddress)) return null;

        try
        {
            ProcessStartInfo processStartInfo = new ProcessStartInfo();

            Process process = new Process();

            processStartInfo.FileName = "arp";

            processStartInfo.RedirectStandardInput = false;

            processStartInfo.RedirectStandardOutput = true;

            processStartInfo.Arguments = "-a " + ipAddress;

            processStartInfo.UseShellExecute = false;

            process = Process.Start(processStartInfo);

            int Counter = -1;

            while (Counter <= -1)
            {                  
                    Counter = macAddress.Trim().ToLower().IndexOf("mac address", 0);
                    if (Counter > -1)
                    {
                        break;
                    }

                    macAddress = process.StandardOutput.ReadLine();
                    if (macAddress != "")
                    {
                        string[] mac = macAddress.Split(' ');
                        if (Array.IndexOf(mac, ipAddress) > -1)                                
                        {
                            if (mac[11] != "")
                            {
                                macAddress = mac[11].ToString();
                                break;
                            }
                        }
                    }
            }
            process.WaitForExit();
            macAddress = macAddress.Trim();
        }

        catch (Exception e)
        {

            Console.WriteLine("Failed because:" + e.ToString());

        }
        return macAddress;

    }
于 2013-04-23T08:56:43.840 回答