チャット アプリケーションに asmack ライブラリを使用しています。Muc ルーム情報を取得するために、ログインに成功した後、以下のコードを使用しています。
MultiUserChat mMultiUserChat = new MultiUserChat(connection,"VjNewMoiosandroid@conference.chat"); mMultiUserChat.join(USERNAME); try { if (mMultiUserChat.isJoined()==true) { RoomInfo roomInfo=mMultiUserChat.getRoomInfo(connection,"VjNewMoiosandroid@conference.chat");} } catch (Exception e) { // TODO: handle exception e.printStackTrace(); }
部屋の情報を取得しているときにこのエラーが発生し、ログで部屋の情報を取得していることをデバッグして確認しますが、roomInfo には何も表示されません。
10-10 08:55:12.388: W/System.err(1821): java.lang.ClassCastException: org.jivesoftware.smack.util.PacketParserUtils$2 は org.jivesoftware.smackx.packet.DiscoverInfo 10-10 にキャストできません08:55:12.428: W/System.err(1821): org.jivesoftware.smackx.ServiceDiscoveryManager.discoverInfo(ServiceDiscoveryManager.java:600) 10-10 08:55:12.458: W/System.err(1821): org.jivesoftware.smackx.ServiceDiscoveryManager.discoverInfo(ServiceDiscoveryManager.java:552) 10-10 08:55:12.478: W/System.err(1821): com.demo.xmppchat.CopyOfXMPPChatDemoActivity.getRoomInfo(CopyOfXMPPChatDemoActivity.java: 469)
ログで受信したチャット ルームの情報
10-10 15:38:10.133: D/SMACK(26035): 03:38:10 PM RCV (1107887640): <iq
from='VjNewMoiosandroid@conference.chat' to='14393671556301070000@chat/Smack'
id='VWaeO-6' type='result'><query xmlns='http://jabber.org/protocol/disco#info'><identity
category='conference' type='text' name='VjNewMoiosandroid'/><feature var='
http://jabber.org/protocol/muc'/><feature var='muc_public'/><feature
var='muc_persistent'/><feature var='muc_open'/><feature var='muc_semianonymous'/><feature
var='muc_moderated'/><feature var='muc_unsecured'/><x xmlns='jabber:x:data'
type='result'><field type='hidden' var='FORM_TYPE'><value>
http://jabber.org/protocol/muc#roominfo</value></field><field label='Room description'
var='muc#roominfo_description'><value></value></field><field label='Number of occupants'
var='muc#roominfo_occupants'><value>1</value></field></x></query></iq>