¿Qué es el perfil iBeacon Bluetooth?

Me gustaría crear mi propio iBeacon con algunos kits de desarrollo de baja energía bluetooth. Apple todavía tiene que lanzar una especificación para iBeacons, sin embargo, algunos desarrolladores de hardware han diseñado el iBeacon de ingeniería inversa a partir del código de ejemplo de AirLocate y han comenzado a vender kits de desarrollo iBeacon.

Entonces, ¿qué es el perfil Bluetooth iBeacon?

Bluetooth Low Energy utiliza el descubrimiento de servicio de perfil GATT for LE. Por lo tanto, creo que necesitamos conocer el Atributo, el Tipo de atributo, el Valor de atributo y, tal vez, los Permisos de atributo del atributo iBeacon. Entonces, para un iBeacon con un UUID de E2C56DB5-DFFB-48D2-B060-D0F5A71096E0 un valor principal de 1 y un valor menor de 1, ¿cuál sería el servicio de perfil Bluetooth GATT?

He aquí algunas suposiciones que he tomado de la discusión en los foros de Apple y en los documentos.

  1. Solo necesita ver el servicio de perfil (GATT) de un periférico Bluetooth para saber que es un iBeacon.

  2. Las claves mayor y menor están codificadas en algún lugar de este servicio de perfil

Heres algunas compañías con iBeacon Dev Kits que parecen tener esta figura ya:

  • http://redbearlab.com/ibeacon/
  • http://kontakt.io/

Esperemos que con el tiempo tengamos un perfil publicado en Bluetooth.org como este: https://www.bluetooth.org/en-us/specification/adopted-specifications

Para un iBeacon con ProximityUUID E2C56DB5-DFFB-48D2-B060-D0F5A71096E0 , mayor 0 , menor 0 y potencia de Tx calibrada de -59 RSSI, el paquete de anuncio BLE transmitido se ve así:

d6 be 89 8e 40 24 05 a2 17 6e 3d 71 02 01 1a 1a ff 4c 00 02 15 e2 c5 6d b5 df fb 48 d2 b0 60 d0 f5 a7 10 96 e0 00 00 00 00 c5 52 ab 8d 38 a5

Este paquete se puede desglosar de la siguiente manera:

 d6 be 89 8e # Access address for advertising data (this is always the same fixed value) 40 # Advertising Channel PDU Header byte 0. Contains: (type = 0), (tx add = 1), (rx add = 0) 24 # Advertising Channel PDU Header byte 1. Contains: (length = total bytes of the advertising payload + 6 bytes for the BLE mac address.) 05 a2 17 6e 3d 71 # Bluetooth Mac address (note this is a spoofed address) 02 01 1a 1a ff 4c 00 02 15 e2 c5 6d b5 df fb 48 d2 b0 60 d0 f5 a7 10 96 e0 00 00 00 00 c5 # Bluetooth advertisement 52 ab 8d 38 a5 # checksum 

La parte clave de ese paquete es el anuncio de Bluetooth, que se puede desglosar así:

 02 # Number of bytes that follow in first AD structure 01 # Flags AD type 1A # Flags value 0x1A = 000011010 bit 0 (OFF) LE Limited Discoverable Mode bit 1 (ON) LE General Discoverable Mode bit 2 (OFF) BR/EDR Not Supported bit 3 (ON) Simultaneous LE and BR/EDR to Same Device Capable (controller) bit 4 (ON) Simultaneous LE and BR/EDR to Same Device Capable (Host) 1A # Number of bytes that follow in second (and last) AD structure FF # Manufacturer specific data AD type 4C 00 # Company identifier code (0x004C == Apple) 02 # Byte 0 of iBeacon advertisement indicator 15 # Byte 1 of iBeacon advertisement indicator e2 c5 6d b5 df fb 48 d2 b0 60 d0 f5 a7 10 96 e0 # iBeacon proximity uuid 00 00 # major 00 00 # minor c5 # The 2's complement of the calibrated Tx Power 

Cualquier dispositivo Bluetooth LE que se pueda configurar para enviar un anuncio específico puede generar el paquete anterior. He configurado una computadora Linux con Bluez para enviar este anuncio, y los dispositivos iOS7 que ejecutan el código de prueba AirLocate de Apple lo recogen como iBeacon con los campos especificados anteriormente. Ver: Usar BlueZ Stack As A Peripheral (Anunciante)

Este blog contiene todos los detalles sobre el proceso de ingeniería inversa.

Parece basado en datos publicitarios, particularmente los datos del fabricante:

 4C00 02 15 585CDE931B0142CC9A1325009BEDC65E 0000 0000 C5        
  • Identificador de la compañía Apple (Little Endian), 0x004c
  • tipo de datos, 0x02 => iBeacon
  • longitud de datos, 0x15 = 21
  • uuid: 585CDE931B0142CC9A1325009BEDC65E
  • mayor: 0000
  • menor: 0000
  • potencia medida a 1 metro: 0xc5 = -59

Tengo este script node.js trabajando en Linux con el ejemplo de ejemplo de la aplicación AirLocate.

Solo para reconciliar la diferencia entre la respuesta de sandeepmistry y la respuesta de davidgyoung:

 02 01 1a 1a ff 4C 00 

Es parte de la especificación del formato de datos publicitarios [1]

  02 # length of following AD structure 01 # <> AD Structure [2] 1a # read as b00011010. # In this case, LE General Discoverable, # and simultaneous BR/EDR but this may vary by device! 1a # length of following AD structure FF # Manufacturer specific data [3] 4C00 # Apple Inc [4] 0215 # ?? some 2-byte header 

Falta de la AD es una definición de Servicio [5]. Creo que el protocolo iBeacon en sí mismo no tiene ninguna relación con el GATT y el descubrimiento de servicios estándar. Si descarga el progtwig iBeacon de RedBearLab, verá que utilizan el GATT para configurar los parámetros de publicidad, pero esto parece ser específico de su implementación, y no parte de la especificación. El progtwig AirLocate no parece usar el GATT para la configuración, por ejemplo, de acuerdo con LightBlue y otros progtwigs similares que probé.

Referencias

  1. Core Bluetooth Spec v4, Vol 3, Parte C, 11
  2. Vol 3, Parte C, 18.1
  3. Vol 3, Parte C, 18.11
  4. https://www.bluetooth.org/en-us/specification/assigned-numbers/company-identifiers
  5. Vol 3, Parte C, 18.2

Si la razón por la que hace esta pregunta es porque desea utilizar Core Bluetooth para publicitarse como iBeacon en lugar de utilizar la API estándar, puede hacerlo fácilmente anunciando un NSDictionary como:

 { kCBAdvDataAppleBeaconKey = ; } 

Vea esta respuesta para más información.

Es muy simple, solo anuncia una cadena que contiene algunos caracteres que se ajustan al estándar iBeacon de Apple. puede consultar el enlace http://glimwormbeacons.com/learn/what-makes-an-ibeacon-an-ibeacon/

iBeacon Profile contiene 31 Bytes que incluye los siguientes

  1. Prefijo – 9 bytes – que incluye s los datos adv y datos del fabricante
  2. UUID – 16 Bytes
  3. Mayor – 2 bytes
  4. Menor – 2 Bytes
  5. TxPower – 1 byte

enter image description here