IOS MDM: общий ключ /id для iOS MDM и поддержка приложения MDM iOS

Я работаю над решением MDM, и я столкнулся с проблемой UDID. У нас есть приложение iOS, которое поддерживает приложение для iOS MDM-сервера. Это поддерживающее приложение можно запустить после того, как устройство iOS зарегистрировано для MDM с нашим сервером MDM.

При регистрации устройства мы можем получить UDID устройства на стороне сервера, и мы используем это UDID устройства как общий ключ для iOS MDM и iOS Supporting. Чтобы войти в систему с нашим MDM-сервером в поддерживающем приложение iOS, пользователь должен предоставить идентификатор пользователя, пароль и UDID, которые мы собираем, используя api [[UIDevice currentDevice] uniqueIdentifier], поэтому для аутентификации требуются эти 3 параметра.

Но Apple отказалась от UDID устройства в iOS 5.0, поэтому мы не можем использовать API-интерфейс apple для захвата UDID устройства в приложении iOS.

Теперь нам нужен какой-то общий ключ, который доступен в сертификате MDM iOS и который мы можем создать в приложении поддержки iOS. Таким образом, какой пользователь зарегистрировал устройство iOS с сервером MDM, только тот пользователь должен иметь возможность входа в приложение поддержки iOS.

1 ответ

Вы можете использовать MAC-адрес wifi также как замену UDID. Логика получения MAC-адреса приведена ниже, которую вы можете использовать в своем поддерживающем приложении iOS для получения адреса mac. Вы можете указать MAC-адрес wifi на стороне сервера, используя команду MDM.

//. h файл

#import <foundation foundation.h="">
@interface MacAddress : NSObject
+ (NSString *)getMacAddress;
@end
</foundation>

//файл имплантации

#import "MacAddress.h"
#import <sys socket.h="">
#import <sys sysctl.h="">
#import <net if.h="">
#import <net if_dl.h="">
@implementation MacAddress
+ (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
</net></net></sys></sys>

licensed under cc by-sa 3.0 with attribution.