XMPP框架与Openfire。

3

我已经搭建了自己的Openfire服务器,并使用Spark和Adium进行了测试。然而,当运行XMPPFramework for iOS的示例项目时,我遇到了以下身份验证错误:

2011-11-16 01:34:26:850 iPhoneXMPP[1245:207] iPhoneXMPPAppDelegate: xmppStream:socketDidConnect:
2011-11-16 01:34:26:850 iPhoneXMPP[1245:8d0f] SEND: <stream:stream xmlns='jabber:client'  xmlns:stream='http://etherx.jabber.org/streams' version='1.0' to='flashmatch.net'>
2011-11-16 01:34:27:464 iPhoneXMPP[1245:7b13] RECV: <stream:stream  xmlns:stream="http://etherx.jabber.org/streams" xmlns="jabber:client" from="ip-10-112-57-167"   id="ff9c2cf2" xml:lang="en" version="1.0"/>
2011-11-16 01:34:27:772 iPhoneXMPP[1245:8d0f] RECV: <stream:features><starttls   xmlns="urn:ietf:params:xml:ns:xmpp-tls"/><mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl"> <mechanism>DIGEST-MD5</mechanism><mechanism>PLAIN</mechanism><mechanism>CRAM-MD5</mechanism></mechanisms><compression xmlns="http://jabber.org/features/compress"><method>zlib</method></compression><auth xmlns="http://jabber.org/features/iq-auth"/><register xmlns="http://jabber.org/features/iq-register"/></stream:features>
2011-11-16 01:34:27:772 iPhoneXMPP[1245:207] iPhoneXMPPAppDelegate: xmppStreamDidConnect:
2011-11-16 01:34:27:772 iPhoneXMPP[1245:207] SEND: <auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='DIGEST-MD5'/>
2011-11-16 01:34:28:079 iPhoneXMPP[1245:7b13] RECV: <challenge xmlns="urn:ietf:params:xml:ns:xmpp-sasl">cmVhbG09ImlwLTEwLTExMi01Ny0xNjciLG5vbmNlPSIycWZoY01JL0R2a0Z0ME41TmNSdGpUaGk0dmVOamk4YUxHMU9LMmZwIixxb3A9ImF1dGgiLGNoYXJzZXQ9dXRmLTgsYWxnb3JpdGhtPW1kNS1zZXNz</challenge>
2011-11-16 01:34:28:079 iPhoneXMPP[1245:7b13] decoded response: username="alan",realm="ip- 10-112-57-167",nonce="2qfhcMI/DvkFt0N5NcRtjThi4veNji8aLG1OK2fp",cnonce="8C2C32EC-532A-4A75-8166-F75387CE2F84",nc=00000001,qop=auth,digest-uri="xmpp/flashmatch.net",response=8b1ad8c7c968a92d36ff6ed895b0ed80,charset=utf-8
2011-11-16 01:34:28:080 iPhoneXMPP[1245:7b13] SEND: <response xmlns="urn:ietf:params:xml:ns:xmpp-sasl">dXNlcm5hbWU9ImFsYW4iLHJlYWxtPSJpcC0xMC0xMTItNTctMTY3Iixub25jZT0iMnFmaGNNSS9EdmtGdDBONU5jUnRqVGhpNHZlTmppOGFMRzFPSzJmcCIsY25vbmNlPSI4QzJDMzJFQy01MzJBLTRBNzUtODE2Ni1GNzUzODdDRTJGODQiLG5jPTAwMDAwMDAxLHFvcD1hdXRoLGRpZ2VzdC11cmk9InhtcHAvZmxhc2htYXRjaC5uZXQiLHJlc3BvbnNlPThiMWFkOGM3Yzk2OGE5MmQzNmZmNmVkODk1YjBlZDgwLGNoYXJzZXQ9dXRmLTg=</response>
2011-11-16 01:34:28:386 iPhoneXMPP[1245:8d0f] RECV: <failure xmlns="urn:ietf:params:xml:ns:xmpp-sasl"><not-authorized/></failure>
2011-11-16 01:34:28:386 iPhoneXMPP[1245:207] iPhoneXMPPAppDelegate: xmppStream:didNotAuthenticate:

当连接talk.google.com时,同样的示例项目运作良好。有人知道这里出了什么问题吗?


我遇到了同样的问题。找到解决方案了吗? - user281300
我也是。有找到解决方案的运气吗? - Dani Pralea
3个回答

5

根据权限问题判断,未查看代码之前很难猜测问题出在哪里,但认证问题表明您的用户JIDs或密码存在问题。因此我可以想到两种可能的问题:

  1. 请确保您已经在Openfire中正确设置了用户和密码。
  2. 第二,请检查“服务器名称”属性是否已正确设置。转到您的管理面板 -> 服务器信息 -> 服务器名称。这应该与iOS项目中用户的域名匹配。让我们来看一个例子:如果您将服务器名称设置为“127.0.0.1”,那么您应该使用 YOURUSER@127.0.0.1,而使用YOURUSER@localhost不起作用会在认证过程中失败。

4

当您尝试登录时,请使用服务器的IP地址提供用户名,例如"JIDname=user@127.0.0.1"

如果您正在尝试登录到指定的域,则在setupStream方法中添加以下代码行

[xmppStream setHostName:@"google.com"];//domain name
[xmppStream setHostPort:5222];//port number

3
您可以在管理员面板中检查openfire服务器名称。

服务器管理器 > 服务器信息 > 服务器名称:[server_name]

主机地址/ IP可能与Server Name中的不同:

[host_address]:9090/ - 管理员面板 [server_name]

如果服务器名称与主机地址不同,则设置如下。在大多数情况下,服务器名称和主机地址相同。因此,在iOS xmppframework身份验证方面没有问题。
xmppStream.hostName = @"hostaddress";
xmppStream.hostPort = 5222;

jabberID = @"username@servername";

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接