Xmpp String utils经常崩溃应用程序

时间:2016-09-20 09:02:50

标签: android nullpointerexception xmpp ejabberd smack

我使用Smack 4.1库开发了聊天应用程序,该库使用ejabberd服务器进行聊天。

所有聊天都能正常运行,但有时应用会因以下错误而崩溃,无法理解为什么会经常发生这种情况?

以下错误来自崩溃: -

Fatal Exception: java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.String.indexOf(int)' on a null object reference
       at org.jxmpp.util.XmppStringUtils.parseBareJid(XmppStringUtils.java:117)
       at org.jivesoftware.smack.roster.Roster$RosterPushListener.handleIQRequest(Roster.java:1386)
       at org.jivesoftware.smack.AbstractXMPPConnection$2.run(AbstractXMPPConnection.java:1051)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
       at java.lang.Thread.run(Thread.java:761)

下面的代码用于连接和登录ejabberd: -

   XMPPTCPConnectionConfiguration.Builder config = XMPPTCPConnectionConfiguration.builder();
    config.setSecurityMode(ConnectionConfiguration.SecurityMode.disabled);
    config.setServiceName(Constants.HOST);
    config.setPort(Constants.PORT);
    config.setHost(Constants.HOST);
    config.setDebuggerEnabled(true);
    config.setSendPresence(true);
    config.setUsernameAndPassword(strUsername + "@" + Constants.HOST, strPassword);


    SASLAuthentication.blacklistSASLMechanism("SCRAM-SHA-1");
    SASLAuthentication.blacklistSASLMechanism("DIGEST-MD5");
    SASLAuthentication.unBlacklistSASLMechanism("PLAIN");
    objXmpptcpConnection = new XMPPTCPConnection(config.build());
    objXmpptcpConnection.setUseStreamManagement(true);
    objXmpptcpConnection.setUseStreamManagementResumption(true);
    try {
        objXmpptcpConnection.connect();
        System.out.println("Connected to===>" + objXmpptcpConnection.getHost());
        objXmpptcpConnection.login();

    } catch (XMPPException e) {
        e.printStackTrace();

    } catch (SmackException e) {
        e.printStackTrace();

    } catch (IOException e) {
        e.printStackTrace();

    }

是否有任何我错过的设置或请建议解决方案以避免此问题?

1 个答案:

答案 0 :(得分:1)

我需要查看代码,看看究竟发生了什么。但是从你的堆栈跟踪看起来就像你的朋友列表中有人被添加,XMPP lib在回调中期望该人的JID。但是你传递的是null,因此崩溃了。

尝试禁用与名册相关的XMPP并查看崩溃是否仍然存在。