BluetoothServerSocket.accept() не возвращает значение, даже если устройство сопряжено

Я разрабатываю приложение Bluetooth для Android на основе примера BluetoothChat. я запускаю сервер Bluetooth и прослушиваю устройство (не телефон), чтобы подключиться к моему приложению через небезопасное соединение rfcomm.

private class AcceptThread extends Thread {
    // The local server socket
    private final BluetoothServerSocket mmServerSocket;

    public AcceptThread(boolean secure) {
        BluetoothServerSocket tmp = null;

        // Create a new listening server socket
        try {
            tmp = mAdapter.listenUsingInsecureRfcommWithServiceRecord(mServiceName, MY_UUID_INSECURE);
        } catch (Exception e) {
            Log.e(TAG, ".AcceptThread # listen() failed", e);
        } 
        mmServerSocket = tmp;
    }

    public void run() {
        BluetoothSocket socket = null;

        // Listen to the server socket if we're not connected
        while (mState != STATE_CONNECTED) {
            try {
                // This is a blocking call and will only return on a
                // successful connection or an exception
                Log.d(TAG, ".AcceptThread.run # ...accepting server socket conn");

                socket = mmServerSocket.accept(); //FIXME: it blocks here

                Log.d(TAG, ".AcceptThread.run # server socket connection accepted");
            } catch (Exception e) {
                MMLog.e(TAG, ".run # accept() failed: "+e);
                connectionFailed();
                break;
            }

            // If a connection was accepted
            if (socket != null) {
                synchronized (BluetoothService.this) {
                    switch (mState) {
                    case STATE_LISTEN:
                    case STATE_CONNECTING:
                        // starting the thread where i will receive input
                        // streams from the other device
                        connected(socket, socket.getRemoteDevice());
                        break;
                    case STATE_NONE:
                    case STATE_CONNECTED:
                        // Either not ready or already connected. Terminate new socket.
                        try {
                            socket.close();
                        } catch (IOException e) {
                            Log.e(TAG, "Could not close unwanted socket", e);
                        }
                        break;
                    }
                }
            }
        }

    }

    public void cancel() {
        try {
            if(mmServerSocket != null) {
                mmServerSocket.close();
            }
        } catch (IOException e) {
            Log.e(TAG, ".cancel # Could not close server socket: ", e);
        }
    }
}

Я использую HTC Desire S, Android 2.3.5. Устройство подключается, но я не получаю данные, потому что соединение блокируется в методе '.accept()'. Он просто продолжает ждать.

socket = mmServerSocket.accept(); //...и ждем

  • Почему он все еще ждет, если устройство сопряжено?
  • Как я могу установить соединение, потому что я также пробовал отражение, и до сих пор нет результата
  • Есть ли проблема со стеком Bluetooth HTC? Кто-нибудь установил соединение, возможно, с помощью другого телефона Android?

person user975349    schedule 10.02.2012    source источник
comment
Есть ли у вас возможность редактировать программное обеспечение Bluetooth на устройстве, к которому вы пытаетесь подключиться?   -  person JPM    schedule 14.02.2012
comment
вам нужно настроить приложение на двух устройствах, и после этого вы увидите, что они могут общаться друг с другом   -  person Majid Golshadi    schedule 15.01.2014


Ответы (2)


Я думаю, что с вашим кодом что-то не так, разве это не должно быть socket = tmp.accept(); вот что мне нужно для подключения к серверу сокетов:

BluetoothServerSocket serverSocket = null;
BluetoothAdapter bta = BluetoothAdapter.getDefaultAdapter();
try {
    serverSocket = bta.listenUsingInsecureRfcommWithServiceRecord("BluetoothChatInsecure", UUID.fromString("00001101-0000-1000-8000-00805F9B34FB"));
} catch (IOException e) { e.printStackTrace(); }

while(!Thread.interrupted()) {
    try {
        socket = serverSocket.accept();
        if (socket != null) {
            Log.d("CONNECTED", "Connected bluetooth");

        /// do your stuff
person JPM    schedule 10.02.2012
comment
спасибо за повтор. Прямо сейчас мне не нужно устройство, чтобы протестировать его, но я свяжусь с вами в понедельник. - person user975349; 10.02.2012
comment
Между тем, я добавил в исходный вопрос весь код, который я тестировал. - person user975349; 10.02.2012
comment
Я заметил это, и, возможно, это как-то связано со специальной версией Android от Motorola 2.3.5 и автосопряжением, которое с createInsecureRfcommSocketToServiceRecord не работает, поэтому, возможно, listenUsingInsecureRfcommWithServiceRecord тоже не работает. - person JPM; 11.02.2012
comment
Я все еще не могу подключиться к устройству. попробую отразить: Method m = mAdapter.getClass().getMethod("listenUsingRfcommOn", new Class[] { int.class }); int port = getRfcommPort(tmp);tmp = (BluetoothServerSocket) m.invoke(mAdapter, port); - person user975349; 13.02.2012

Скорее всего, это связано с другим вашим устройством (это происходит со мной). Ваш Android уже выполняет свою работу по отображению входящих подключений. Есть много причин, по которым ваше специальное устройство не будет правильно инициировать подключение к вашему телефону Android:

  • Устройство таинственным образом переключается на другой профиль Bluetooth, например. HDP вместо SPP
  • Устройство каким-то образом помнит в своей памяти другой Android-телефон (к которому последний раз подключались или что-то в этом роде) и продолжает пытаться подключиться к этому телефону, но не к тому, который вы используете прямо сейчас.

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

person ericn    schedule 28.08.2013