如何拦截来自Openfire服务器的Ping消息?

时间:2013-01-21 23:20:52

标签: java plugins xmpp openfire

我正在编写一个Openfire插件来拦截服务器在客户端空闲时发送给客户端的Ping消息。系统Ping看起来像:

<iq from='capulet.lit' to='juliet@capulet.lit/balcony' id='s2c1' type='get'>
  <ping xmlns='urn:xmpp:ping'/>
</iq>

但是,当我使用PacketInterceptor拦截服务器和客户端之间的所有数据包时,拦截器能够拦截Ping的所有数据包EXCEPT。我不明白发生了什么。任何帮助将非常感激!

2 个答案:

答案 0 :(得分:1)

在这里,您可以找到一个最简单的数据包拦截器示例,它记录每个传入和传出的数据包。 http://faisalbhagat.blogspot.com/2014/03/openfire-logging-using-packetinterceptor.html

答案 1 :(得分:0)

下面是我的插件中的覆盖方法intercepPacket,它可以拦截ping消息。 供您参考〜:)

@Override
public void interceptPacket(org.xmpp.packet.Packet packet, Session session,
        boolean incoming, boolean processed) throws PacketRejectedException {
    if (incoming && !processed) {
        String packetXml = packet.toXML();
        logger.warn("\n" + new XmlFormatter().format(packetXml));
    }
}