2016-07-04 2 views
2

Я пытаюсь разработать приложение для чата, все работает нормально, когда интернет стабилен. как я могу отправлять и получать сообщения. но когда интернет уходит на некоторое время, xmpp закрывает соединение. когда приходит интернет, я пытаюсь подключиться к серверу. после успешного повторного подключения я получил ошибку потока Client already logged in и соединение автоматически закрывается.Повторное подключение к серверу xmpp с использованием smack

Вот мой код приемника трансляции, чтобы проверить подключение к Интернету.

networkReceiver = new BroadcastReceiver(){ 
     @Override 
     public void onReceive(Context context, Intent intent) { 
      //super.onReceive(context, intent); 
      if(intent.getExtras()!=null) { 
       NetworkInfo ni=(NetworkInfo) intent.getExtras().get(ConnectivityManager.EXTRA_NETWORK_INFO); 
       if(ni!=null && ni.getState()==NetworkInfo.State.CONNECTED) { 
        enableChat(); 
       } 
      } 
      else if(intent.getExtras().getBoolean(ConnectivityManager.EXTRA_NO_CONNECTIVITY,Boolean.FALSE)) { 
       disableChat(); 
      } 
      else{ 
       disableChat(); 
      } 
     } 

    }; 

вот код для включения чата и отключения чата.

public static void disableChat() { 

    msg_edittext.setClickable(false); 
    sendButton.setClickable(false); 
    form.setClickable(false); 

    msg_edittext.setEnabled(false); 
    sendButton.setEnabled(false); 
    form.setEnabled(false); 
    showNoInternetView(); 
    if (xmpp.getConnection()!=null) 
    xmpp.getConnection().disconnect(); 

} 

public static void showNoInternetView() { 
    linrNoInternet.setVisibility(View.VISIBLE); 
    msgListView.setVisibility(View.GONE); 
} 

public static void showInternetView() { 
    linrNoInternet.setVisibility(View.GONE); 
    msgListView.setVisibility(View.VISIBLE); 
} 
    public static void enableChat() { 
    msg_edittext.setClickable(true); 
    sendButton.setClickable(true); 
    form.setClickable(true); 

    showInternetView(); 

    msg_edittext.setEnabled(true); 
    sendButton.setEnabled(true); 
    form.setEnabled(true); 
    xmpp.connect("reconnect.."); 

} 

при попытке восстановить ошибка входа это свидетельствует ..

07-04 10:25:52.880 8581-8612/com.vario.community D/xmpp: Authenticated! 
07-04 10:25:52.880 8581-9732/com.vario.community D/SMACK: SENT (0): <iq  id='BpGkK-5' type='get'><query xmlns='jabber:iq:roster'></query></iq> 
07-04 10:25:52.882 8581-8612/com.vario.community D/SMACK: XMPPConnection authenticated (0) 
07-04 10:25:52.882 8581-8612/com.vario.community I/LOGIN: Yey! We're connected to the Xmpp server! 
07-04 10:25:52.883 8581-8612/com.vario.community D/SMACK: XMPPConnection connected (0) 
07-04 10:25:52.883 8581-9732/com.vario.community D/SMACK: SENT (0): <presence id='BpGkK-6'><c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='http://www.igniterealtime.org/projects/smack' ver='E6FpoDPmjMQ3i53V+HWh0YBrS7U='/></presence> 
07-04 10:25:52.884 8581-9732/com.vario.community D/SMACK: SENT (0): <iq id='BpGkK-18' type='set'><bind xmlns='urn:ietf:params:xml:ns:xmpp-bind'></bind></iq> 
07-04 10:25:52.885 8581-9732/com.vario.community D/SMACK: SENT (0): <r xmlns='urn:xmpp:sm:3'/> 
07-04 10:25:52.886 8581-9732/com.vario.community D/SMACK: SENT (0): <iq id='BpGkK-20' type='get'><query xmlns='jabber:iq:roster'></query></iq> 
07-04 10:25:52.886 8581-8612/com.vario.community E/(reconnect..): SMACKException: Client is already logged in 
07-04 10:25:52.888 8581-9732/com.vario.community D/SMACK: SENT (0): <presence id='BpGkK-21'><c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='http://www.igniterealtime.org/projects/smack' ver='JcQq0xyVq6PbVQSN9PSQq58gxiQ='/></presence> 
07-04 10:25:52.890 8581-8581/com.vario.community V/TextView: stopSelectionActionMode() 
07-04 10:25:52.893 8581-9732/com.vario.community D/SMACK: SENT (0): <presence id='BpGkK-22' type='unavailable'><c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='http://www.igniterealtime.org/projects/smack' ver='JcQq0xyVq6PbVQSN9PSQq58gxiQ='/></presence> 
07-04 10:25:52.893 8581-9732/com.vario.community D/SMACK: SENT (0): <a xmlns='urn:xmpp:sm:3' h='0'/> 
07-04 10:25:52.894 8581-9732/com.vario.community D/SMACK: SENT (0): </stream:stream> 

07-04 10:25:57.935 8581-9032/com.vario.community E/Roster: Exception reloading roster 
                 org.jivesoftware.smack.SmackException$NoResponseException: No response received within reply timeout. Timeout was 5000ms (~5s). Used filter: IQReplyFilter: iqAndIdFilter (AndFilter: (OrFilter: (IQTypeFilter: type=error, IQTypeFilter: type=result), StanzaIdFilter: id=BpGkK-20)), : fromFilter (OrFilter: (FromMatchesFilter (full): null, FromMatchesFilter (bare): [email protected], FromMatchesFilter (full): vario.fitness)). 
                  at org.jivesoftware.smack.AbstractXMPPConnection$6.run(AbstractXMPPConnection.java:1443) 
                  at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:422) 
                  at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
                  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:152) 
                  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:265) 
                  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112) 
                  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587) 
                  at java.lang.Thread.run(Thread.java:818) 

Так что, если кто-нибудь знает процесс правильного пересоединения, пожалуйста, помогите мне. Я искал этот вопрос, но у меня пока нет решения.

спасибо :)

+0

Я думаю, что это может быть проблема вашего xmpp-сервера. На вашем сервере необходимо проверить доступность клиента, используя присутствие iq на основе некоторого интервала времени. Если клиент не отвечает, сервер должен изменить статус клиента в автономный. Если клиент подключен между этот сервер продолжительности должен разрешить механизм пересоединения. Вновь проверьте свою базу данных сервера еще раз. –

+0

Я тебя не понял. вы говорите, что, как только клиент закрывает соединение, сервер должен изменить статус присутствия правильно? .. Если это, то я попытался отправить статус недоступным до отключения в случае сбоя интернета. но он также дает мне ошибку «Нет ответа от сервера» и не подключен к серверу. – Newbiee

+0

Plz проверяет как на стороне клиента, так и на стороне сервера эту проблему, тогда только он может быть разрешен. Например, сервер должен всегда проверять доступность клиента с использованием строфы присутствия на основе сервера клиент должен отправить ответ на сервер, тогда только сервер должен поддерживать статус сеанса входа в клиент. Если предполагается, что некоторые клиенты не отвечают на пинг сервера, сервер автоматически закрывает этот сеанс входа в систему. Таким образом, главная красота сервера xmpp, а затем только большая часть чата приложений, использующих этот протокол xmpp. –

ответ

1

Это известная ошибка в Смак: SMACK-725.

Обратите внимание, что я не рекомендую использовать ReconnectionManager на Android. Вместо этого я предлагаю реализовать собственную логику пересоединения, предназначенную для мобильной среды, и использовать информацию, которую предоставляет Android (например, прослушивание намерения CONNECTIVITY_CHANGED).

+0

спасибо, я посмотрю. но какая альтернатива? как я должен снова подключиться? – Newbiee

+0

Обновить мой ответ – Flow

+0

Спасибо за комментарий, я попытаюсь реализовать альтернативу. – Newbiee

Смежные вопросы