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)
有人可以请帮助到底哪里出了问题。
提前致谢 !
从 paho dev 邮件列表中得到了这个答案。
因为connect是异步的,可能在你调用subscribe的时候没有建立连接。如果您使用的是 IMqttToken connect(MqttConnectOptions options, Object userContext, IMqttActionListener callback),您应该 waitForCompletion 或在 IMqttActionListener.onSuccess 中调用 subscribe
虽然 waitForCompletion 给了服务器超时错误,订阅监听器的 onSuccess 方法解决了这个问题。
| 归档时间: |
|
| 查看次数: |
1725 次 |
| 最近记录: |