Android BLE错误0x06请求不支持

问题描述:

我的应用程序在连接到BLE设备时遇到问题。在应用程序所做的每个连接尝试中,都会在OnConnectionStateChange()方法中获取错误代码0x0006(请求不支持)。我已经尝试过蓝牙关/开,但仍然出现相同的错误。Android BLE错误0x06请求不支持

我在LG D410(Android 5.0.2)中遇到了这个问题。在将我的LG手机升级到5.0.2后,应用程序开始出现此错误。 我的应用程序工作正常与三星Galaxy S4(Android 5.1),Nexus 5(Android 6.0)。

为什么我会收到此错误?可以做些什么来解决它?

这是错误的日志:

02-26 05:30:53.919 D/MyBluetoothClass-1392940(21607): trying to connect with address: 78:A5:04:86:D4:16 02-26 05:30:53.944 D/MyBluetoothClass-1392940(21607): Create a new GATT connection. 02-26 05:30:53.945 D/BluetoothGatt(21607): connect() - device: 78:A5:04:86:D4:16, auto: true 02-26 05:30:53.945 D/BluetoothGatt(21607): registerApp() 02-26 05:30:53.945 D/BluetoothGatt(21607): registerApp() - UUID=a81c9b62-f822-4e42-9af0-752a8eab82a1 02-26 05:30:53.947 D/BluetoothGatt(21607): onClientRegistered() - status=0 clientIf=5 02-26 05:30:53.947 D/MyBluetoothClass-1392940(21607): Connection attempt started; results reported asynchronously 02-26 05:30:53.947 D/BluetoothGatt(21607): refresh() - device: 78:A5:04:86:D4:16 02-26 05:30:53.950 D/BluetoothGatt(21607): onClientConnectionState() - status=6 clientIf=5 device=78:A5:04:86:D4:16 02-26 05:30:53.951 D/MyBTGattCallback(21607): onConnectionStateChange, newState: 0 02-26 05:30:53.951 E/MyBTGattCallback(21607): onConnectionStateChange status 0006 desc Req not supported

我认为这是在运行Android Lollipop版本BlueDroid框架的问题。 如果使用connectGatt(Context context, boolean autoConnect, BluetoothGattCallback callback) pass autoConnect = false;

使autoConnect true导致棒棒糖版本中的onClientConnectionState异常,但是,适用于棉花糖。

我做了它的工作。

@Override 
protected void onStart() { 
    super.onStart(); 
    Log.d(TAG,"connecting Gatt"); 
    bluetoothGatt = bleScanResult.getBluetoothDevice().connectGatt(this, false, callback); 
} 


@Override 
    protected void onStop() { 
     super.onStop(); 
     if (bluetoothGatt != null) { 
      Log.d(TAG,"disconnecting Gatt"); 
      bluetoothGatt.disconnect(); 
      bluetoothGatt.close(); 
      bluetoothGatt = null; 
     } 
    }