Ошибка аутентификации XMPP, если я использую механизм X-FACEBOOK-PLATFORM - PullRequest
1 голос
/ 03 марта 2012

Я пытаюсь создать приложение для чата в Facebook.
И я хочу войти на сервер XMPP через механизм X-FACEBOOK-PLATFORM.
Но мне не удалось получить шаг аутентификации.
Если яиспользуя механизм DIGEST-MD5, я могу успешно войти на сервер XMPP (в этом случае я использовал JID в качестве имени пользователя@chat.facebook.com и пароль в качестве своего пароля в Facebook)
Для механизма X-FACEBOOK-PLATFORM я использовалJID как uid@chat.facebook.com и не было проблем с получением моего токена доступа, uid, даты истечения срока действия и т. Д.
Конечно, я получил разрешение «xmpp_login» от Facebook.

Что былонеправильно?

Вот расшифрованное сообщение журнала.

AppDelegate: xmppStream:socketDidConnect:
SEND: <?xml version='1.0'?>
SEND: <stream:stream xmlns='jabber:client' xmlns:stream='http://etherx.jabber.org/streams' version='1.0' to='chat.facebook.com'>
RECV: <stream:stream xmlns="jabber:client" xmlns:stream="http://etherx.jabber.org/streams" id="FAA1CDE5" from="chat.facebook.com" version="1.0" stream1:lang="en"/>
RECV: <stream:features xmlns:stream="http://etherx.jabber.org/streams"><starttls xmlns="urn:ietf:params:xml:ns:xmpp-tls"/><mechanisms xmlns="urn:ietf:params:xml:ns:xmpp-sasl"><mechanism>X-FACEBOOK-PLATFORM</mechanism><mechanism>DIGEST-MD5</mechanism></mechanisms></stream:features>
SEND: <auth xmlns='urn:ietf:params:xml:ns:xmpp-sasl' mechanism='X-FACEBOOK-PLATFORM'/>
XMPPCapabilities: My capabilities:
<query xmlns="http://jabber.org/protocol/disco#info">
  <feature var="http://jabber.org/protocol/disco#info"/>
  <feature var="http://jabber.org/protocol/caps"/>
</query>
RECV: <challenge xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
      version=1&method=auth.xmpp_login&nonce=0E51AA2E42C4AF8FCE9D996F347C7019</challenge>
SEND: <response xmlns="urn:ietf:params:xml:ns:xmpp-sasl">
    method=auth.xmpp_login&nonce=0E51AA2E42C4AF8FCE9D996F347C7019&access_token=BAAEctIrR99oBAM9ZBymJSDmVZAYb82RX634ANVZCQ9VJeoD9ZCTqSGVyuxSQfbm9s92VGtwcewVJlP7C8CnIglkqZBCvq6ZBxxWhJoDmK0rPJGdM5i7KRu18bZAJoyKEI0ZD
    &api_key=313036725417946
    &call_id=150701328
    &v=1.0</response>
RECV: <failure xmlns="urn:ietf:params:xml:ns:xmpp-sasl"><not-authorized/></failure>
AppDelegate: xmppStream:didNotAuthenticate:
AppDelegate: xmppStreamDidDisconnect:withError:

Ответы [ 2 ]

2 голосов
/ 11 августа 2013

Я также столкнулся с подобной проблемой и решил проблему, обеспечив безопасность xmppstream перед аутентификацией

-(void)xmppStreamDidConnect:(XMPPStream *)sender{

DDLogVerbose(@"%@: %@", THIS_FILE, THIS_METHOD);

isXmppConnected = YES;

if (![xmppStream isSecure])
{
    NSError *error = nil;
    BOOL result = [xmppStream secureConnection:&error];

    if (result == NO)
    {
        DDLogError(@"%@: Error in xmpp STARTTLS: %@", THIS_FILE, error);
        NSLog(@"XMPP STARTTLS failed");
    }
}
else
{
    NSError *error = nil;
    BOOL result = [xmppStream authenticateWithFacebookAccessToken:[NSString stringWithFormat:@"%@",FBSession.activeSession.accessTokenData] error:&error];

    if (result == NO)
    {
        DDLogError(@"%@: Error in xmpp auth: %@", THIS_FILE, error);
        NSLog(@"XMPP authentication failed");
    }
}
}
0 голосов
/ 05 июня 2012

Попробуйте «-uid@chat.facebook.com» вместо «uid@chat.facebook.com».

...