ejabberd MAM不与Strophe js合作

时间:2015-07-15 08:05:28

标签: javascript xml ejabberd strophe

即使在用户注销和登录后,我也试图显示两个用户之间的对话。我的意思是当user1注销并再次登录时,他应该看到与user2进行的对话。我正在使用Ejabberd XMPP服务器和Strophe Js来检索消息。

我发现这个strophe.mam.js插件可以执行此操作,但会引发错误而无法获取消息。

这是我的代码:

function onConnect(status)
    {
        // Functions runs while users trys to login to the XMPP server
        var iq = null;

        switch (status)
        {
            case Strophe.Status.CONNECTING:
                log('Connecting.');
                break;
            case Strophe.Status.CONNFAIL:
                log('Failed to connect.');
                $('#connect').get(0).value = 'connect';
                break;
            case Strophe.Status.DISCONNECTING:
                log('Disconnecting.');
                break;
            case Strophe.Status.DISCONNECTED:
                log('Disconnected.');
                $('#connect').get(0).value = 'connect';
                break;
            case Strophe.Status.CONNECTED:
                log('Connected.');
                connection.addHandler(onMessage, null, 'message', null, null,  null);
                connection.addHandler(onPresence, null, 'presence', null, null, null);

                iq = $iq({type: 'get'}).c('query', {xmlns: 'jabber:iq:roster'});
                connection.sendIQ(iq, onRoster);

                break;
            default:
                break;
        }
    }

function onMessage(msg) {
    debugger;
    var fromJid = msg.getAttribute("from"),
        bareFromJid = Strophe.getBareJidFromJid(fromJid),
        type = msg.getAttribute("type"),
        elems = msg.getElementsByTagName("body");

    if (type == "chat" && elems.length > 0) {
        var body = elems[0],
            message = Strophe.getText(body);

        showMessage(bareFromJid + ": " + message);
              connection.mam.query("yashwanth@localhost", {
  "with": bareFromJid,
  onMessage: function(message) {
            console.log("Message from " + bareFromJid,
                ": " + message);
            return true;
  },
  onComplete: function(response) {
            console.log("Got all the messages");
  }
    });
    }

    return true;
}

function send() {
    // Handles with sending the message
    var to = $('#to-jid').get(0).value,
        myBareJid = Strophe.getBareJidFromJid(connection.jid);
        message = $('#message').get(0).value,
        reply = $msg({to: to, type: 'chat'})
            .c("body")
            .t(message);

    connection.send(reply.tree());
    showMessage(myBareJid + ": " + message);
}

$(document).ready(function () {
    connection = new Strophe.Connection(BOSH_SERVICE);
    messagebox = $("#messages");
    messagebox.val("");
    logbox = $("#log-messages");
    logbox.val("");
    rosterbox = $("#roster");
    rosterbox.val("");
    connection.rawInput = function (data) { log('RECV: ' + data); };
    connection.rawOutput = function (data) { log('SEND: ' + data); };

    Strophe.log = function (level, msg) { log('LOG: ' + msg); };

    login();
    $('#send').bind('click', send);
});

因此,每当用户收到消息时,控制台中都会显示某些内容。但它在我的日志中返回了这个错误

RECV: <body xmlns='http://jabber.org/protocol/httpbind'><iq xmlns='jabber:client' 
from='yashwanth@localhost' to='yashwanth@localhost/22064184271436881211352579' 
id='yashwanth@localhost' type='error'><query xmlns='urn:xmpp:mam:0'><x xmlns='jabber:x:data'><field 
var='FORM_TYPE'><value>urn:xmpp:mam:0</value></field><field var='with'>
<value>shabda@localhost</value></field></x><set xmlns='http://jabber.org/protocol/rsm'/></query>
<error code='400' type='modify'><bad-request xmlns='urn:ietf:params:xml:ns:xmpp-stanzas'/></error>
</iq></body>

请帮我解决这个问题

2 个答案:

答案 0 :(得分:1)

您的MAM查询格式不正确。

您缺少xmlns type="submit"功能的x元素上的属性jabber:x:data。类型在XEP-0004 Data Forms

中是必填项

你的智商应该是:

<iq type='set' id='juliet1'>
  <query xmlns='urn:xmpp:mam:0'>
    <x xmlns='jabber:x:data' type='submit'>
      <field var='FORM_TYPE' type='hidden'>
        <value>urn:xmpp:mam:0</value>
      </field>
      <field var='with'>
        <value>shabda@localhost</value>
      </field>
    </x>
    <set xmlns='http://jabber.org/protocol/rsm'/>
  </query>
</iq>

参见XEP-0313 Message Archive Management中的例6。

MAM strophe插件有一个bug。我们在这里准备了一个修补程序:https://github.com/processone/strophejs-plugins/commit/5a7857e2ab625c0521c68719d7e220f00c32c593

并提交了此拉取请求:https://github.com/strophe/strophejs-plugins/pull/65

答案 1 :(得分:1)

我遇到了MAM的问题。请看这个链接:https://www.ejabberd.im/forum/25028/solved-how-configure-and-test-modmam-message-archive-management

我解决了问题更改类型&#39;设置&#39;到&#39;得到&#39;