Аватары на основе OpenPire-сервера, Android-клиент

У меня настроен сервер openfire, и с ним хорошо работают мои андроид-клиенты, за исключением того, что я не могу публиковать аватары, проблема в том, что сервер просто игнорирует пакет iq публикации аватара, ошибок нет, ничего в файлах журнала. Я использую стандартную XMPP pep avatar stanza, пожалуйста, hep

Спасибо всем за ваши ответы. Я обнаружил, что проблема связана с сервером openfire 3.10, который не анализирует стандартную строфу XEP 0084. Фактически я обнаружил, что журналы и сервер зависали, поэтому я изменил IQ, например, это должно быть стандартом. IQ для публикации аватара

<iq type='set' from='juliet@capulet.lit/chamber' id='publish1'>
  <pubsub xmlns='http://jabber.org/protocol/pubsub'>
    <publish node='urn:xmpp:avatar:data'>
      <item id='111f4b3c50d7b0df729d299bc6f8e9ef9066971f'>
        <data xmlns='urn:xmpp:avatar:data'>
          qANQR1DBwU4DX7jmYZnncm...
        </data>
      </item>
    </publish>
  </pubsub>
</iq>

но, как вы можете видеть, в стандартном IQ нет адреса "to", сервер openfire создает узел pubsub в БД и вылетает и не отвечает с результатом, запрашивая у пользователя публикацию метаданных, поэтому мне нужно было отправить этот пакет, а затем стандартный пакет метаданных, но затем снова отправить пакет метаданных с адресом "to", на который сервер ответил бы в результате того, что уведомление метаданных выполнится как стандартные метаданные, которые будут отправлены на сервер в первый раз,

<iq type='set' from='juliet@capulet.lit/chamber' id='publish2'>
      <pubsub xmlns='http://jabber.org/protocol/pubsub'>
        <publish node='urn:xmpp:avatar:metadata'>
          <item id='111f4b3c50d7b0df729d299bc6f8e9ef9066971f'>
            <metadata xmlns='urn:xmpp:avatar:metadata'>
              <info bytes='12345'
                    id='111f4b3c50d7b0df729d299bc6f8e9ef9066971f'
                    height='64'
                    type='image/png'
                    width='64'/>
            </metadata>
          </item>
        </publish>
      </pubsub>
    </iq>

а затем снова, как это с добавлением адреса "к"

<iq type='set' from='juliet@capulet.lit/chamber' to="mydomain.com" id='publish2'>
  <pubsub xmlns='http://jabber.org/protocol/pubsub'>
    <publish node='urn:xmpp:avatar:metadata'>
      <item id='111f4b3c50d7b0df729d299bc6f8e9ef9066971f'>
        <metadata xmlns='urn:xmpp:avatar:metadata'>
          <info bytes='12345'
                id='111f4b3c50d7b0df729d299bc6f8e9ef9066971f'
                height='64'
                type='image/png'
                width='64'/>
        </metadata>
      </item>
    </publish>
  </pubsub>
</iq>

Таким образом, публикация аватара работает, и я также успешно отправляю уведомление другим пользователям.

и вот сервер сбой журнала в случае

2016.03.02 10:41:02 ERROR [socket_c2s-thread-3]: org.jivesoftware.openfire.handler.IQHandler - Internal server error
java.lang.NullPointerException
    at org.jivesoftware.openfire.pubsub.PubSubEngine.createNodeHelper(PubSubEngine.java:1165)
    at org.jivesoftware.openfire.pubsub.PubSubEngine.publishItemsToNode(PubSubEngine.java:340)
    at org.jivesoftware.openfire.pubsub.PubSubEngine.process(PubSubEngine.java:98)
    at org.jivesoftware.openfire.pep.PEPServiceManager.process(PEPServiceManager.java:215)
    at org.jivesoftware.openfire.pep.IQPEPHandler.handleIQ(IQPEPHandler.java:423)
    at org.jivesoftware.openfire.handler.IQHandler.process(IQHandler.java:66)
    at org.jivesoftware.openfire.IQRouter.handle(IQRouter.java:372)
    at org.jivesoftware.openfire.IQRouter.route(IQRouter.java:115)
    at org.jivesoftware.openfire.spi.PacketRouterImpl.route(PacketRouterImpl.java:78)
    at org.jivesoftware.openfire.net.StanzaHandler.processIQ(StanzaHandler.java:342)
    at org.jivesoftware.openfire.net.ClientStanzaHandler.processIQ(ClientStanzaHandler.java:99)
    at org.jivesoftware.openfire.net.StanzaHandler.process(StanzaHandler.java:307)
    at org.jivesoftware.openfire.net.StanzaHandler.process(StanzaHandler.java:199)
    at org.jivesoftware.openfire.nio.ConnectionHandler.messageReceived(ConnectionHandler.java:181)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain$TailFilter.messageReceived(DefaultIoFilterChain.java:690)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:417)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:47)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:765)
    at org.apache.mina.core.filterchain.IoFilterAdapter.messageReceived(IoFilterAdapter.java:109)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:417)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:47)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:765)
    at org.apache.mina.filter.codec.ProtocolCodecFilter$ProtocolDecoderOutputImpl.flush(ProtocolCodecFilter.java:407)
    at org.apache.mina.filter.codec.ProtocolCodecFilter.messageReceived(ProtocolCodecFilter.java:236)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:417)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:47)
    at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:765)
    at org.apache.mina.core.filterchain.IoFilterEvent.fire(IoFilterEvent.java:74)
    at org.apache.mina.core.session.IoEvent.run(IoEvent.java:63)
    at org.apache.mina.filter.executor.OrderedThreadPoolExecutor$Worker.runTask(OrderedThreadPoolExecutor.java:769)
    at org.apache.mina.filter.executor.OrderedThreadPoolExecutor$Worker.runTasks(OrderedThreadPoolExecutor.java:761)
    at org.apache.mina.filter.executor.OrderedThreadPoolExecutor$Worker.run(OrderedThreadPoolExecutor.java:703)
    at java.lang.Thread.run(Unknown Source)

0 ответов

Другие вопросы по тегам