基于Android蓝牙聊天示例的应用程序服务发现失败

时间:2013-09-24 09:15:11

标签: android bluetooth

我正在编写一款基于Android蓝牙聊天样本的蓝牙部分蓝牙游戏。我有两部手机需要测试。这是问题,当我将一部手机连接到另一部手机时,它有时会显示“无法连接设备”捆绑包,但是当我运行蓝牙聊天样本时,它从未显示过这个,所以我认为这不是设备的问题。有没有人研究过蓝牙聊天样本,并且有同样的问题会给我一些帮助?

我尝试打印异常,就像“java.io.IOException:服务发现失败”。以下是导致异常的代码。

private class ConnectThread extends Thread {
    private final BluetoothSocket mmSocket;
    private final BluetoothDevice mmDevice;

    public ConnectThread(BluetoothDevice device) {
        mmDevice = device;
        BluetoothSocket tmp = null;

        // Get a BluetoothSocket for a connection with the
        // given BluetoothDevice
        try {
            tmp = device.createRfcommSocketToServiceRecord(MY_UUID);
        } catch (IOException e) {
            Log.e(TAG, "create() failed", e);
        }
        mmSocket = tmp;
    }

    public void run() {
        Log.i(TAG, "BEGIN mConnectThread");
        setName("ConnectThread");

        // Always cancel discovery because it will slow down a connection
        mAdapter.cancelDiscovery();

        // Make a connection to the BluetoothSocket
        try {
            // This is a blocking call and will only return on a
            // successful connection or an exception
            mmSocket.connect();
        } catch (IOException e) {
            Log.e("error", e.toString());
            connectionFailed();
            // Close the socket
            try {
                mmSocket.close();
            } catch (IOException e2) {
                Log.e(TAG, "unable to close() socket during connection failure", e2);
            }
            // Start the service over to restart listening mode
            BluetoothChatService.this.start();
            return;
        }

        // Reset the ConnectThread because we're done
        synchronized (BluetoothChatService.this) {
            mConnectThread = null;
        }

        // Start the connected thread
        connected(mmSocket, mmDevice);
    }

    public void cancel() {
        try {
            mmSocket.close();
        } catch (IOException e) {
            Log.e(TAG, "close() of connect socket failed", e);
        }
    }
} 

确切的位置是
           mmSocket.connect();

1 个答案:

答案 0 :(得分:2)

我知道你会觉得答案很奇怪,老实说我不是很擅长UUID。但我遇到了同样的问题,并使用它解决了问题。

<强>答案
我认为您正在使用BluetoothChat应用中硬编码的UUID。当我将这些UUID更改为一个众所周知的UUID,即; “00001105-0000-1000-8000-00805F9B34FB”它解决了我的问题,我不再得到IOException--Service Discovery Failed

所以,我建议你改变:

来自:

private static final UUID MY_UUID_SECURE =
    UUID.fromString("ea87c0d0-afac-11de-8a39-0800200c9a66");
private static final UUID MY_UUID_INSECURE =
    UUID.fromString("7ce255c0-200a-11e0-ac64-0800200c9a66");


private static final UUID MY_UUID_SECURE = 
    UUID.fromString("00001105-0000-1000-8000-00805F9B34FB");
private static final UUID MY_UUID_INSECURE = 
    UUID.fromString("00001105-0000-1000-8000-00805F9B34FB");

Source这个答案。