Ejabberd XMPPException $ XMPPErrorException:XMPPError:service-unavailable - 取消,加入MUC

时间:2016-07-22 18:27:18

标签: android xmpp ejabberd smack

好吧,我面临一个奇怪的问题。我能够创建muc,能够邀请用户,能够加入但是一段时间后我无法加入新创建的组。 这仅针对某些用户,而其他用户可以创建/加入群组。 我正在创建MUC组:

MultiUserChatManager manager = MultiUserChatManager.getInstanceFor(getConnection());
            MultiUserChat chatRoom = manager.getMultiUserChat(groupName+ "@conference." + Constants.XMPP_SERVICE);

            chatRoom.createOrJoin(chatGroup.title);

用户邀请如下:

 MultiUserChatManager manager = MultiUserChatManager.getInstanceFor(getConnection());
                        MultiUserChat chatRoom = manager.getMultiUserChat(groupName+ "@conference." + Constants.XMPP_SERVICE);
chatRoom.changeNickname(FirstName);
                                chatRoom.invite(invite.UserId + "@" + Constants.XMPP_SERVICE, groupInfo);

另一端我有

 @Override
    public void invitationReceived(XMPPConnection conn, final MultiUserChat room, String inviter, final String reason, String password, final Message message) {
        Log.d("XMPPInvitation", "");
        try {
            room.join(FirstName);

上面的代码工作正常,但一段时间后它开始给出以下错误:

org.jivesoftware.smack.XMPPException$XMPPErrorException: XMPPError: service-unavailable - cancel
 at org.jivesoftware.smack.PacketCollector.nextResultOrThrow(PacketCollector.java:232)
at org.jivesoftware.smackx.muc.MultiUserChat.enter(MultiUserChat.java:311)
at org.jivesoftware.smackx.muc.MultiUserChat.join(MultiUserChat.java:495)
at org.jivesoftware.smackx.muc.MultiUserChat.join(MultiUserChat.java:430)
at com.app.xmpp.GroupChatInvitationListener.invitationReceived(GroupChatInvitationListener.java:45)

我在GroupChatInvitationListener.java:45有room.join 我在收到的XML中也注意到了这一点

<presence from='c09b59da-1d5b-4783-9346-93c23edc0660@conference.MyHOST/A J 33' to='31bc27e9-c650-4870-aaab-ca7285848954@MyHOST/A J 33' type='error' xml:lang='en' id='WC0zt-374'><x xmlns='http://jabber.org/protocol/muc'/><c xmlns='http://jabber.org/protocol/caps' hash='sha-1' node='http://www.igniterealtime.org/projects/smack' ver='os2Kusj3WEOivn5n4iFr/ZEO8ls='/><error code='503' type='cancel'><service-unavailable xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/></error></presence>

如果我从Ejabberd Admin重新启动mod_muc模块,它将再次开始工作。 你能说出可能出现的问题吗?

1 个答案:

答案 0 :(得分:0)

嗯,问题是在MUC实施中,如果MUC中没有用户在线,则服务器将使该MUC无效。即使所有者也无法再次加入该组,如果它已空(没有在线学员在那里)。

要解决这个问题,我们必须使用MUC-SUB实现作为魅力,但它目前是实验性的,但它有效:)