订阅 MqttAndroidClient 上的主题时出现 NullPointerException

Rav*_*avi 1 android nullpointerexception mqtt

我使用了 Paho Eclipse repo 中的 Android Service jar。在客户端连接后订阅任何主题时,我遇到了 NUllPOinterException。

    public void connect(View view) {

    MqttConnectOptions conOpt = new MqttConnectOptions();

    String uri = "tcp://" + host + ":" + port;
    boolean cleanSession = true;
    // int timeout = 60 ;
    // int keepalive = 60 ;
    clientHandle = uri + clientId;

    MqttAndroidClient client;
    client = Connections.getInstance(this)
            .createClient(this, uri, clientId);

    Connection conn = new Connection(clientHandle, clientId, host, port,
            this, client, sslConnection);

    conOpt.setCleanSession(cleanSession);
    // conOpt.setConnectionTimeout(timeout);
    conOpt.setKeepAliveInterval(100);;

    MqttCallbackHandler callback = new MqttCallbackHandler(this,
            MainActivity.this, clientHandle);

    conn.addConnectionOptions(conOpt);
    Connections.getInstance(this).addConnection(conn);
    String[] topics = { "hello", "hi" };
    int qos = 0;
    try {
        IMqttToken t = client.connect(conOpt, null, new ActionListener(this,
                Action.CONNECT, uri, (String[]) null));
        //t.waitForCompletion(90);
        client.setCallback(callback);
        IMqttToken token = Connections
                .getInstance(this)
                .getConnection(clientHandle)
                .getClient()
                .subscribe(
                        "shatinTopic",
                        qos,
                        null,
                        new ActionListener(this, Action.SUBSCRIBE, uri,
                                topics));
        Log.d("SUBSCRIBE", token.getResponse().toString());
    } catch (MqttException e) {
        e.getCause();
    } catch (NullPointerException e) {
        e.getCause();
    } catch (Exception e) {
        e.getCause();
    }
}
Run Code Online (Sandbox Code Playgroud)

错误:

11-09 15:17:24.702: E/AndroidRuntime(26671): Caused by: java.lang.NullPointerException
11-09 15:17:24.702: E/AndroidRuntime(26671): at      org.eclipse.paho.android.service.MqttAndroidClient.subscribe(MqttAndroidClient.java:788)
Run Code Online (Sandbox Code Playgroud)

有人可以请帮助到底哪里出了问题。

提前致谢 !

Rav*_*avi 5

从 paho dev 邮件列表中得到了这个答案。

因为connect是异步的,可能在你调用subscribe的时候没有建立连接。如果您使用的是 IMqttToken connect(MqttConnectOptions options, Object userContext, IMqttActionListener callback),您应该 waitForCompletion 或在 IMqttActionListener.onSuccess 中调用 subscribe

虽然 waitForCompletion 给了服务器超时错误,订阅监听器的 onSuccess 方法解决了这个问题。