[英]Smack XMPP Java: How to access the original XML reprsentation of a ByteStreamRequest (OPEN)?
I need to access the original XML representation of a byte stream initialisation, since I need to communicate with a custom implementation.我需要访问字节流初始化的原始 XML 表示,因为我需要与自定义实现进行通信。 The toXML method just rebuilds the XMLStructur.
toXML 方法只是重建 XMLStructur。
I already tried to implement a custom debugger with a subscribe implementation, but the StreamElement does also not contain the original sent XML data.我已经尝试使用订阅实现来实现自定义调试器,但 StreamElement 也不包含原始发送的 XML 数据。
Solved by implementing a subscribe debugger which can forward raw XML logs to a listener.通过实现可以将原始 XML 日志转发到侦听器的订阅调试器来解决。 Example:
例子:
public class SubscribeDebugger extends SmackDebugger {公共类 SubscribeDebugger 扩展 SmackDebugger {
private static List<IncomingRequestDebugListener> incomingRequestDebugListeners = new ArrayList<>();
private static List<OutgoingRequestDebugListener> outgoingRequestDebugListeners = new ArrayList<>();
private static Boolean enableOutputToConsole;
private static SmackDebugger consoleDebugger;
private ReaderListener readerListener;
private WriterListener writerListener;
private ObservableWriter writer;
private ObservableReader reader;
public SubscribeDebugger(XMPPConnection connection) {
super(connection);
if (this.getEnableOutputToConsole()) {
consoleDebugger = new ConsoleDebugger(connection);
}
readerListener = str -> notifyIncomingRequestDebugListeners(str.toString());
writerListener = str -> notifyOutgoingRequestDebugListeners(str.toString());
}
public Boolean getEnableOutputToConsole() { return enableOutputToConsole; }
public static void setEnableOutputToConsole(Boolean active) {
enableOutputToConsole = active;
}
/*Static part since a debugger will be initiated by xmpp connection. Smack does not
provide access on the debugger instances. All instances share the listeners.*/
public static void registerIncomingRequestDebugListener (IncomingRequestDebugListener listener) {
incomingRequestDebugListeners.add(listener);
}
public static void unregisterIncomingRequestDebugListener(IncomingRequestDebugListener listener) {
incomingRequestDebugListeners.remove(listener);
}
public static void registerOutgoingRequestDebugListener (OutgoingRequestDebugListener listener) {
outgoingRequestDebugListeners.add(listener);
}
public static void unregisterOutgoingRequestDebugListener(OutgoingRequestDebugListener listener) {
outgoingRequestDebugListeners.remove(listener);
}
protected void notifyIncomingRequestDebugListeners (String streamElement) {
incomingRequestDebugListeners.parallelStream().forEach((listener) -> {
listener.onRequestReceived(streamElement);
});
}
protected void notifyOutgoingRequestDebugListeners (String streamElement) {
outgoingRequestDebugListeners.parallelStream().forEach((listener) -> {
listener.onRequestSent(streamElement);
});
}
@Override
public void userHasLogged(EntityFullJid user) {
}
@Override
public Reader newConnectionReader(Reader reader) {
ObservableReader debugReader = new ObservableReader(reader);
debugReader.addReaderListener(readerListener);
reader = debugReader;
if (enableOutputToConsole && consoleDebugger != null)
return consoleDebugger.newConnectionReader(reader);
return reader;
}
@Override
public Writer newConnectionWriter(Writer writer) {
if(enableOutputToConsole && consoleDebugger != null)
return consoleDebugger.newConnectionWriter(writer);
return writer;
}
@Override
public void onIncomingStreamElement(TopLevelStreamElement streamElement) {
if(enableOutputToConsole && consoleDebugger != null)
consoleDebugger.onIncomingStreamElement(streamElement);
}
@Override
public void onOutgoingStreamElement(TopLevelStreamElement streamElement) {
if (enableOutputToConsole && consoleDebugger != null)
consoleDebugger.onOutgoingStreamElement(streamElement);
}
} }
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.