2016-09-20 52 views
1

P.S.結論を出す前に全体の質問をお読みください。接続が失われました(32109) - java.io.EOFException(MqttAndroidClient)

connectメソッドが呼び出されるたびに、私は次の例外を取得しています:

接続は(32109)を失った - org.eclipse.paho.client.mqttv3.internal.CommsReceiver.runでjava.io.EOFException を(CommsReceiver.java:146) at java.lang.Thread.run(Thread.java:818) 原因:java.io.EOFException at java.io.DataInputStream.readByte(DataInputStream.java:77) at org.eclipse.paho.client.mqttv3.internal.wire.MqttInputStream.readMqttWireMessage(MqttInputStream.java:65) at org.eclipse.paho.client.mqttv3.internal.CommsReceiver.run (CommsReceiver.java:107)

私はいくつかのコードスニペットを試みましたが、両方とも同じ例外が発生しています。私は、同じサーバーURIのをしようとした場合

方法1

private final String serverUri = "tcp://95.177.135.232:9001"; 

private void mqqtConnectAndroidClient() { 
    String clientId = "clientID-" + MqttClient.generateClientId(); 
    mqttAndroidClient = new MqttAndroidClient(getMainActivity(), serverUri, clientId); 
    MqttConnectOptions mqttConnectOptions = new MqttConnectOptions(); 
    mqttConnectOptions.setKeepAliveInterval(60); 
    mqttConnectOptions.setCleanSession(true); 
    mqttConnectOptions.setMqttVersion(MqttConnectOptions.MQTT_VERSION_3_1_1); 
    try { 
     mqttAndroidClient.connect(mqttConnectOptions, null, new IMqttActionListener() { 
      @Override 
      public void onSuccess(IMqttToken asyncActionToken) { 
       subscribeToTopic(); 
      } 

      @Override 
      public void onFailure(IMqttToken asyncActionToken, Throwable exception) { 
       AppLog.Error("Failed to connect to: " + serverUri); 
       exception.printStackTrace(); 
      } 
     }); 
    } catch (MqttException e) { 
     e.printStackTrace(); 
    } 
} 

方法2

private final String serverUri = "tcp://95.177.135.232:9001"; 

private void methodTwo() { 
    try { 
     MqttDefaultFilePersistence mdfp = new MqttDefaultFilePersistence(MQTT_DIR); 
     mqttClient = new MqttClient(serverUri, "1", mdfp); 
     MqttConnectOptions options = new MqttConnectOptions(); 
     options.setMqttVersion(MqttConnectOptions.MQTT_VERSION_3_1_1); 
     options.setKeepAliveInterval(60); 
     options.setAutomaticReconnect(true); 
     options.setCleanSession(true); 
     mqttClient.connect(options); 
     mqttClient.subscribe("#"); 
     mqttClient.setCallback(new MqttCallback() { 

      @Override 
      public void connectionLost(Throwable arg0) { 
       AppLog.Error("Connection lost"); 
       try { 
        mqttClient.connect(); 
       } catch (MqttException e) { 
        e.printStackTrace(); 
       } 
      } 

      @Override 
      public void deliveryComplete(IMqttDeliveryToken arg0) { 
       AppLog.Error("deliveryComplete"); 
      } 

      @Override 
      public void messageArrived(String arg0, MqttMessage arg1) throws Exception { 
       AppLog.Error("messageArrived"); 
       AppLog.Error(arg1.toString()); 
      } 
     }); 
    } catch (MqttException e) { 
     AppLog.Error("Main Exception"); 
     e.printStackTrace(); 
    } 
} 

方法

public void subscribeToTopic() { 
    try { 
     String subscriptionTopic = "#"; 
     mqttAndroidClient.subscribe(subscriptionTopic, 0, null, new IMqttActionListener() { 
      @Override 
      public void onSuccess(IMqttToken asyncActionToken) { 
       AppLog.Error("Subscribed!"); 
      } 
      @Override 
      public void onFailure(IMqttToken asyncActionToken, Throwable exception) { 
       AppLog.Error("Failed to subscribe"); 
      } 
     }); 
    } catch (MqttException ex) { 
     System.err.println("Exception whilst subscribing"); 
     ex.printStackTrace(); 
    } 
} 

を購読HiveMQ、適切な接続で完全に正常に動作しており、サブスクリプションからも結果が得られます。

コンパイル 'org.eclipse.paho:org.eclipse.paho.client.mqttv3:1.1.0' コンパイル「org.eclipse.paho:org.eclipse.paho私は、次の2つのライブラリを使用しています.android.service:1.0.2'

私はSOの答えのいくつかを試してみましたがOneTwoThreeFourFiveが好きそれらのどれも私のために働いていません。

ご協力いただければ幸いです。前もって感謝します!

答えて

3

ポート9001を使用していて、HiveMQリンクがWebSocket over MQTTクライアントを指しています。

tcp://で始まる接続URIを指定しています。これは、サービスに、WebSocket上のMQTTではなくネイティブMQTTと接続する必要があることを通知します。

Websocketサポートを実装するためのレポートのbugに記載されているように、クライアントコードでWebソケットを使用するように知らせるには、接続URIをws://で開始する必要があります。

+0

はい、あなたは正しいです。私はws://を試しましたが、Webソケットクライアントを使っていましたが、その場合は拒否していました。 –

関連する問題