【问题标题】:feature not implemented nodejs xmpp android功能未实现nodejs xmpp android
【发布时间】:2016-06-25 17:36:21
【问题描述】:

我正在尝试在不使用 Google 消息服务和 nodejs xmpp 服务器的情况下创建一个聊天应用程序。 所以我使用了this node js xmpp server 和 smack api for android app。

我不知道为什么,但服务器正在发送节说功能未实现。

我编写的连接xmpp服务器的android代码。

XMPPTCPConnectionConfiguration config = XMPPTCPConnectionConfiguration.builder()
                    .setServiceName("localhost")
                    .setHost(IPADRESS)
                    .setPort(5222)
                    .build();
            AbstractXMPPConnection conn2 = new XMPPTCPConnection(config);
            conn2.setPacketReplyTimeout(1000);
            SmackConfiguration.DEBUG = true;
            conn2.connect();

            conn2.login(mngr.getDeviceId(), "secret");

nodejs xmpp 服务器模块

var startServer = function (done) {
  // Sets up the server.
  server = new xmpp.C2S.TCPServer({
    port: 5222,
    domain: 'localhost'
  })

  // On connection event. When a client connects.
  server.on('connection', function (client) {
    // That's the way you add mods to a given server.

    // Allows the developer to register the jid against anything they want
    client.on('register', function (opts, cb) {
      console.log('REGISTER')
      cb(true)
    })

    // Allows the developer to authenticate users against anything they want.
    client.on('authenticate', function (opts, cb) {
      console.log('server:', opts.username, opts.password, 'AUTHENTICATING')
      if (opts.password === 'secret') {
        console.log('server:', opts.username, 'AUTH OK')
        cb(null, opts)
      } else {
        console.log('server:', opts.username, 'AUTH FAIL')
        cb(false)
      }
    })

    client.on('online', function () {
      console.log('server:', client.jid.local, 'ONLINE')
     client.send("")

    })

    // Stanza handling
    client.on('stanza', function (stanza) {
      console.log('server:', client.jid.local, 'stanza', stanza.toString())
      var from = stanza.attrs.from
      stanza.attrs.from = stanza.attrs.to
      stanza.attrs.to = from
      client.send(stanza)
    })
    // Stanza handling
    client.on('chat', function (stanza) {
      console.log('server:', client.jid.local, 'chat', stanza.toString())
      client.send(stanza)
    });

    // On Disconnect event. When a client disconnects
    client.on('disconnect', function () {
      console.log('server:',  'DISCONNECT')
    })
  })

  server.on('listening', done)
}
startServer(function (){

    console.log("server localhost started at 5222 localport");
});

nodejs 服务器控制台输出。

server localhost started at 5222 localport
server: 354223060799129 secret AUTHENTICATING
server: 354223060799129 AUTH OK
server: 354223060799129 ONLINE
server: 354223060799129 stanza <iq id="eW469-5" type="get" xmlns:stream="http://etherx.jabber.org/streams" from="354223060799129@localhost/Smack"><query xmlns="jabber:iq:roster"/></iq>
server: 354223060799129 stanza <presence id="eW469-6" xmlns:stream="http://etherx.jabber.org/streams" from="354223060799129@localhost/Smack"/>
server: 354223060799129 stanza <iq id="eW469-5" type="error" xmlns:stream="http://etherx.jabber.org/streams" from="354223060799129@localhost/Smack"><error type="cancel"><feature-not-implemented xmlns="urn:ietf:params:xml:ns:xmpp-stanzas"/></error></iq>

安卓日志:

03-10 22:57:12.598 8126-8183/gcm.play.android.samples.com.gcmquickstart E/AbstractXMPPConnection: Exception in packet listener
                                                                                                  java.lang.NullPointerException: Attempt to invoke virtual method 'int java.lang.Object.hashCode()' on a null object reference
                                                                                                      at java.util.concurrent.ConcurrentHashMap.get(ConcurrentHashMap.java:746)
                                                                                                      at org.jivesoftware.smack.roster.Roster$PresencePacketListener.getUserPresences(Roster.java:1134)
                                                                                                      at org.jivesoftware.smack.roster.Roster$PresencePacketListener.processPacket(Roster.java:1157)
                                                                                                      at org.jivesoftware.smack.AbstractXMPPConnection$4.run(AbstractXMPPConnection.java:1156)
                                                                                                      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                                                                                      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                                                                                      at java.lang.Thread.run(Thread.java:818)
03-10 22:57:12.598 8126-8185/gcm.play.android.samples.com.gcmquickstart E/Roster: Exception reloading roster
                                                                                  XMPPError: feature-not-implemented - cancel
                                                                                      at org.jivesoftware.smack.AbstractXMPPConnection$5.processPacket(AbstractXMPPConnection.java:1448)
                                                                                      at org.jivesoftware.smack.AbstractXMPPConnection$3.run(AbstractXMPPConnection.java:1126)
                                                                                      at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
                                                                                      at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
                                                                                      at java.lang.Thread.run(Thread.java:818)

我为 stackoverflow 中类似类型的问题尝试了很多解决方案,但没有奏效。我们将不胜感激。

【问题讨论】:

    标签: android node.js xmpp


    【解决方案1】:

    您链接的节点 XMPP 服务器项目不是完整的 XMPP 服务器。它是一个 XMPP 服务器库,可帮助您使用 node.js 构建 XMPP 服务器。

    在您的日志中,当您尝试请求名册(联系人列表)时,它会返回未实现的异常。

    您要么必须在 Javascript 中实现所需的所有功能,要么选择另一个现有功能完整的 XMPP 软件。

    【讨论】:

    • 我是 xmpp 新手。如何实现 xmpp 功能。有文档吗?
    • 去这里:xmpp.org/extensions/index.html 并学习 RFC 6120 和 6121。或者正如我建议的那样,从一个完整的 XMPP 服务器开始。你可以在这里找到一些选项:xmpp.org/software/servers.html
    • 谢谢。是否有任何关于使用现有服务器和编写我们自己的服务器的文档?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-12-12
    • 2021-04-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多