Аутентификация XMPP SASL на Ejabberd с помощью PHP


Я пытаюсь пройти аутентификацию на сервере XMPP с использованием SASL.

/**
     * Send Authentication, SASL
     * @return Bool
     * @param $username String
     * @param $password String
     */
    function authenticate($username, $password) {
        $this->username = $username;
        $this->password = $password;

        var_dump($username, $password, $this->domain);

        $auth = base64_encode($username.'@'.$this->domain."\u0000".$username."\u0000".$password);
        $xml = '<auth mechanism="PLAIN" xmlns="urn:ietf:params:xml:ns:xmpp-sasl">'.$auth.'</auth>';
        if ($this->write($xml)) {
            if ($xml = $this->listen(1, true)) {
                if (preg_match("/<success/i", $xml)) {
                    $this->authenticated = $this->_sendStream();
                }
            }
        }
        $this->events->trigger('authenticate', $this->authenticated);
        return $this->authenticated;
    }

Однако сервер XMPP отвечает:

<failure xmlns='urn:ietf:params:xml:ns:xmpp-sasl'><bad-protocol/></failure>

Это против сервера Ejabberd. Когда я открываю поток XMPP, он объявляет:

<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></mechanisms><register xmlns='http://jabber.org/features/iq-register'/></stream:features>

Поэтому мне кажется, что SASL-PLAIN должен работать. У меня есть версия JavaScript, которая отлично работает на сервере OpenFire. (В данный момент я не могу проверить это на Ejabberd)

sendAuthentication: function() {
        clearTimeout(XMPP.sendAuthentication_timer);
        var auth = Base64.encode(XMPP.username+'@'+XMPP.domain+'\u0000'+XMPP.username+'\u0000'+XMPP.password);
        mySocket.events.receive.observe(XMPP.receivedAuthSuccess, function() {
            mySocket.send('<auth mechanism="PLAIN" xmlns="urn:ietf:params:xml:ns:xmpp-sasl">' + auth + '</auth>');
        });
    }

Поэтому я не могу понять, почему версия PHP не работает.

Author: bucabay, 2009-08-01

2 answers

Попробуйте сделать это на Python:

Username+"@xmpp.poppen.lab"+ chr(0) + Username + chr(0) + Password

И для PHP также используйте chr(0) вместо "\u0000"

 2
Author: caibaohua, 2011-04-11 08:28:44

Выяснил, в чем была проблема. EJabberd будет рекламировать SASL PLAIN и DIGEST-MD5, но на самом деле будет принимать только DIGEST-MD5.

 1
Author: bucabay, 2009-08-01 19:31:42