Подтвердить что ты не робот

Android Bluetooth Low Energy Pairing

Как подключить устройство Bluetooth Low Energy (BLE) с Android для чтения зашифрованных данных.

Используя информацию на странице Android BLE, я могу обнаружить устройство, подключиться к нему, обнаружить службы и прочитать незашифрованные характеристики.

Когда я пытаюсь прочитать зашифрованный признак (тот, который заставит iOS показывать всплывающее окно, запрашивающее пару, а затем завершить чтение), я получаю код с ошибкой 5, что соответствует Недостаточная аутентификация.

Я не уверен, как подключить устройство или предоставить информацию об аутентификации для чтения.

Я играл с BluetoothGattCharacteristics, пытаясь добавить дескрипторы, но это тоже не сработало.
Любая помощь приветствуется!

4b9b3361

Ответ 1

Когда вы получите ошибку GATT_INSUFFICIENT_AUTHENTICATION, система начнет процесс связывания для вас. В приведенном ниже примере я пытаюсь включить уведомления и указания на мониторе глюкозы. Сначала я включаю уведомления о характеристике измерения глюкозы, которые могут вызвать ошибку.

@Override
    public void onDescriptorWrite(BluetoothGatt gatt, BluetoothGattDescriptor descriptor, int status) {
        if (status == BluetoothGatt.GATT_SUCCESS) {
            if (GM_CHARACTERISTIC.equals(descriptor.getCharacteristic().getUuid())) {
                mCallbacks.onGlucoseMeasurementNotificationEnabled();

                if (mGlucoseMeasurementContextCharacteristic != null) {
                    enableGlucoseMeasurementContextNotification(gatt);
                } else {
                    enableRecordAccessControlPointIndication(gatt);
                }
            }

            if (GM_CONTEXT_CHARACTERISTIC.equals(descriptor.getCharacteristic().getUuid())) {
                mCallbacks.onGlucoseMeasurementContextNotificationEnabled();
                enableRecordAccessControlPointIndication(gatt);
            }

            if (RACP_CHARACTERISTIC.equals(descriptor.getCharacteristic().getUuid())) {
                mCallbacks.onRecordAccessControlPointIndicationsEnabled();
            }
        } else if (status == BluetoothGatt.GATT_INSUFFICIENT_AUTHENTICATION) {
            // this is where the tricky part comes

            if (gatt.getDevice().getBondState() == BluetoothDevice.BOND_NONE) {
                mCallbacks.onBondingRequired();

                // I'm starting the Broadcast Receiver that will listen for bonding process changes

                final IntentFilter filter = new IntentFilter(BluetoothDevice.ACTION_BOND_STATE_CHANGED);
                mContext.registerReceiver(mBondingBroadcastReceiver, filter);
            } else {
                // this situation happens when you try to connect for the second time to already bonded device
                // it should never happen, in my opinion
                Logger.e(TAG, "The phone is trying to read from paired device without encryption. Android Bug?");
                // I don't know what to do here
                // This error was found on Nexus 7 with KRT16S build of Andorid 4.4. It does not appear on Samsung S4 with Andorid 4.3.
            }
        } else {
            mCallbacks.onError(ERROR_WRITE_DESCRIPTOR, status);
        }
    };

Где mBondingBroadcastReceiver:

private BroadcastReceiver mBondingBroadcastReceiver = new BroadcastReceiver() {
    @Override
    public void onReceive(final Context context, final Intent intent) {
        final BluetoothDevice device = intent.getParcelableExtra(BluetoothDevice.EXTRA_DEVICE);
        final int bondState = intent.getIntExtra(BluetoothDevice.EXTRA_BOND_STATE, -1);
        final int previousBondState = intent.getIntExtra(BluetoothDevice.EXTRA_PREVIOUS_BOND_STATE, -1);

        Logger.d(TAG, "Bond state changed for: " + device.getAddress() + " new state: " + bondState + " previous: " + previousBondState);

        // skip other devices
        if (!device.getAddress().equals(mBluetoothGatt.getDevice().getAddress()))
            return;

        if (bondState == BluetoothDevice.BOND_BONDED) {
            // Continue to do what you've started before
            enableGlucoseMeasurementNotification(mBluetoothGatt);

            mContext.unregisterReceiver(this);
            mCallbacks.onBonded();
        }
    }
};

Не забудьте отменить регистрацию широковещательного приемника при выходе из операции. Возможно, он не был зарегистрирован самим получателем.

Ответ 3

Вам может потребоваться проверить файл spp.c Kernel, какой метод paring его вызывает для paring. 1) passkey 2) Просто работайте и т.д. я предполагаю, что если он сможет вызывать уровень безопасности MIMT и passkey, не будет никакой проверки подлинности. Убедитесь, что все флаги установлены для вызова методов ключа SMP. трек, помещая некоторую печать в файл smp.c.

Решение, которое работает в ICS: с инструментом btmgmt в android и подключением к нему в API шифрования. с ключом доступа или любыми другими способами. оно работает. Возможно, вам потребуется добавить API-интерфейсы passkey в btmgmt из последнего кода bluez.