Переподключение к серверу xmpp с помощью smack
Я пытаюсь разработать приложение для чата, все работает нормально, когда интернет стабилен. как будто я могу посылать и получать сообщения. но когда интернет отключается на некоторое время, xmpp закрывает соединение. когда интернет возвращается, я пытаюсь снова подключиться к серверу. после успешного повторного подключения я получил ошибку потока Client already logged in
и соединение автоматически закрывается.
Вот мой код широковещательного приемника для проверки подключения к интернету.
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): darshan350@vario.fitness, 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)
Так что, если кто-то знает процесс правильного повторного подключения, пожалуйста, помогите мне. я искал этот вопрос, но пока не нашел решения.
Спасибо :)
1 ответ:
Это известная ошибка в Smack: SMACK-725.
Обратите внимание, что я не рекомендую использовать ReconnectionManager на Android. Вместо этого я предлагаю реализовать собственную логику переподключения для мобильной среды и использовать информацию, предоставляемую Android (например, прослушивание connectivity_changed intent).