Ошибка соединения с Bluetooth "java.io.IOException: сбой чтения, закрытие сокета или тайм-аут, чтение ret: -1"
Я пытаюсь подключить устройства через мое приложение, установленное в Nexus 5. Я хочу сделать приложение, подобное радужным контактам в Android. В моем приложении я пытаюсь подключиться к другому устройству через Bluetooth и передавать набор контактов или файлов. Я последовал этому вопросу, но обходной путь, упомянутый там, не работает для меня. Вот мой полный код. Это фрагмент кода из моего приложения, где я попытался получить сокет и установить соединения.
Я могу пройти через диалоговое окно устройства сопряжения, но когда я пытаюсь спарить, возникает ошибка
//to create socket
if (secure) {
bluetoothSocket = device.createRfcommSocketToServiceRecord(uuid);
} else {
bluetoothSocket = device.createInsecureRfcommSocketToServiceRecord(uuid);
}
//connection establishment
try {
bluetoothSocket.connect();
success = true;
break;
} catch (IOException e) {
//try the fallback
try {
Class<?> clazz = tmp.getRemoteDevice().getClass();
Class<?>[] paramTypes = new Class<?>[] {Integer.TYPE};
Method m = clazz.getMethod("createRfcommSocket", paramTypes);
Object[] params = new Object[] {Integer.valueOf(1)};
bluetoothSocket = (BluetoothSocket) m.invoke(tmp.getRemoteDevice(), params);
Thread.sleep(500);
bluetoothSocket.connect();
success = true;
break;
} catch (FallbackException e1) {
Log.w("BT", "Could not initialize FallbackBluetoothSocket classes.", e);
} catch (InterruptedException e1) {
Log.w("BT", e1.getMessage(), e1);
} catch (IOException e1) {
Log.w("BT", "Fallback failed. Cancelling.", e1);
}
}
Ошибка, которую я получаю
09-06 13:44:57.247 27860-27860/com.example.gauravdubey.myapplication I/BT﹕ Attempting to connect to Protocol: 00001101-0000-1000-8000-00805f9b34fb
09-06 13:44:57.247 27860-27860/com.example.gauravdubey.myapplication W/BluetoothAdapter﹕ getBluetoothService() called with no BluetoothManagerCallback
09-06 13:44:57.247 27860-27860/com.example.gauravdubey.myapplication D/BluetoothSocket﹕ connect(), SocketState: INIT, mPfd: {ParcelFileDescriptor: FileDescriptor[56]}
09-06 13:44:58.667 27860-27860/com.example.gauravdubey.myapplication W/BluetoothAdapter﹕ getBluetoothService() called with no BluetoothManagerCallback
09-06 13:44:58.667 27860-27860/com.example.gauravdubey.myapplication D/BluetoothSocket﹕ connect(), SocketState: INIT, mPfd: {ParcelFileDescriptor: FileDescriptor[59]}
09-06 13:45:03.267 27860-27860/com.example.gauravdubey.myapplication W/BT﹕ Fallback failed. Cancelling.
java.io.IOException: read failed, socket might closed or timeout, read ret: -1
at android.bluetooth.BluetoothSocket.readAll(BluetoothSocket.java:505)
at android.bluetooth.BluetoothSocket.waitSocketSignal(BluetoothSocket.java:482)
at android.bluetooth.BluetoothSocket.connect(BluetoothSocket.java:324)
at com.example.gauravdubey.myapplication.BluetoothConnector$FallbackBluetoothSocket.connect(BluetoothConnector.java:198)
at com.example.gauravdubey.myapplication.BluetoothConnector.connect(BluetoothConnector.java:62)
at com.example.gauravdubey.myapplication.ConnectThread.run(ConnectThread.java:101)
at com.example.gauravdubey.myapplication.MainActivity$1.onItemClick(MainActivity.java:288)
at android.widget.AdapterView.performItemClick(AdapterView.java:299)
at android.widget.AbsListView.performItemClick(AbsListView.java:1113)
at android.widget.AbsListView$PerformClick.run(AbsListView.java:2911)
at android.widget.AbsListView$3.run(AbsListView.java:3645)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5001)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
at dalvik.system.NativeStart.main(Native Method)
09-06 13:45:03.267 27860-27860/com.example.gauravdubey.myapplication V/connectThread﹕ Could not connect to device: B0:D0:9C:8B:A4:47
09-06 13:45:03.267 27860-27860/com.example.gauravdubey.myapplication I/Choreographer﹕ Skipped 361 frames! The application may be doing too much work on its main thread.
Так что я делаю неправильно? любая помощь будет оценена
Ответы
Ответ 1
В конструкторе BluetoothConnector.java передается список uuidCandidates.
public BluetoothConnector(BluetoothDevice device, boolean secure, BluetoothAdapter adapter,
List<UUID> uuidCandidates)
{
this.device = device;
this.secure = secure;
this.adapter = adapter;
this.uuidCandidates = uuidCandidates;
if (this.uuidCandidates == null || this.uuidCandidates.isEmpty()) {
this.uuidCandidates = new ArrayList<UUID>();
this.uuidCandidates.add(UUID.fromString("fa87c0d0-afac-11de-8a39-0800200c9a66"));
}
}
Вы передали его null?
Если да, попробуйте позвонить device.fetchUuidsWithSdp()
для устройства Bluetooth, которое вы хотите подключить, и получить намерение BluetoothDevice.ACTION_UUID
в вашем приемнике. Так как это приведет к отображению списка uuids, поддерживаемых устройством.
Ответ 2
В рамках try
("//try the fallback") используйте это:
socket =(BluetoothSocket) device.getClass().getMethod("createRfcommSocket", new Class[] {int.class}).invoke(device,1);
socket.connect();
Другим советом может быть использование другого UUID, он может решить проблему.
Я не знаю, попробовал ли вы это, но так же, как это было сделано в примере Bluetooth-чата, перед созданием ConnectThread вызовите эту функцию:
public synchronized void connect(BluetoothDevice device) {
// Cancel any thread attempting to make a connection
if (mState == STATE_CONNECTING) {
if (mConnectThread != null) {
mConnectThread.cancel();
mConnectThread = null;
}
}
// Cancel any thread currently running a connection
if (mConnectedThread != null) {
mConnectedThread.cancel();
mConnectedThread = null;
}
// Start the thread to connect with the given device
mConnectThread = new ConnectThread(device);
mConnectThread.start();
setState(STATE_CONNECTING);
}
Ответ 3
У меня есть эта самая странная вещь в системе Android 5.0, вам, возможно, придется очистить кеш, как предлагается здесь: http://www.gottabemobile.com/2014/12/01/nexus-lollipop-problems-fixes/
а также вам может потребоваться отсоединить bt-ключ, чтобы он не занимал предыдущее соединение в памяти, если вы используете компьютер и дешевый передатчик bt-ключа
Ответ 4
Грязный кеш. Найдите, где на устройстве очистить кеш приложения, а затем перезагрузите его. Возможно, у вас есть прерыватель управления потоком устройств (брандмауэр, стена приложения, программное обеспечение безопасности), который перехватывает порт и переизлучает it--. В зависимости от того, где он запускается при запуске, он теперь отличается от того, что хочет ваше приложение. Поэтому переконфигурируйте таблицу, отредактировав кеш и перезагрузив ее, чтобы создать таблицы кэширования/перенаправления. Я знаю, что это звучит нечестиво эфемерно, но это сработало для меня.