Akh*_*Dad 18 android xmpp asmack
我正面临使用XEP-0198流管理的问题.
基本上,我想在互联网断开连接并且服务器仍然在线存在客户端时,在Android上启用此消息丢弃问题.
为了解决这个问题,我想使用XEP-0198,它使用请求和确认过程.你可以在这里找到更多.
基本上我使用的是sm:3.问题是,当我设置
XMPPConnection.DEBUG_ENABLED=true;
Run Code Online (Sandbox Code Playgroud)
我在日志中得到sm:3,这是asmack的内部,但我无法通过连接找到任何packetListner.
这就是asmack调试打印内容:
<r xmlns='urn:xmpp:sm:3'/><message from='test1@pinmessage.com/Smack' to='test1@pinmessage.com' id='CQUe6-5'><received xmlns='urn:xmpp:receipts' id='CQUe6-4'/></message><r xmlns='urn:xmpp:sm:3'/>
Run Code Online (Sandbox Code Playgroud)
这是我从packetFilter得到的:
<message id="CQUe6-5" to="test1@pinmessage.com" from="test1@pinmessage.com/Smack"><received xmlns='urn:xmpp:receipts' id='CQUe6-4'/></message>
Run Code Online (Sandbox Code Playgroud)
我曾经通过查看聊天安全和yaxim的代码尝试过自定义数据包过滤器,但是我没有得到如何<r xmlns='urn:xmpp:sm:3'/>
在我的代码中获得这个,以便我可以将收到的数据包的数量现在返回到服务器,以便服务器可以发送我支持任何丢失的数据包.
我还通过添加以下代码为此配置了提供程序管理器:
addSimplePacketExtension("sm", URN_SM_3);
addSimplePacketExtension("r", URN_SM_3);
addSimplePacketExtension("a", URN_SM_3);
addSimplePacketExtension("enabled", URN_SM_3);
addSimplePacketExtension("resumed", URN_SM_3);
addSimplePacketExtension("failed", URN_SM_3);
private static final String URN_SM_3 = "urn:xmpp:sm:3";
private static void addSimplePacketExtension(final String name, final String namespace) {
Log.e("adding simple packet extension", namespace+"---"+name);
ProviderManager.getInstance().addExtensionProvider(name, namespace,
new PacketExtensionProvider() {
public PacketExtension parseExtension(XmlPullParser parser) throws Exception {
StreamHandlingPacket packet = new StreamHandlingPacket(name, namespace);
Log.e("Stream ahndling packet ","------>"+packet.toXML());
int attributeCount = parser.getAttributeCount();
for (int i = 0 ; i < attributeCount ; i++) {
packet.addAttribute(parser.getAttributeName(i), parser.getAttributeValue(i));
}
return (PacketExtension) packet;
}
});
}
static class StreamHandlingPacket extends Packet {
private String name;
private String namespace;
Map<String, String> attributes;
StreamHandlingPacket(String name, String namespace) {
this.name = name;
this.namespace = namespace;
attributes = Collections.emptyMap();
}
public void addAttribute(String name, String value) {
if (attributes == Collections.EMPTY_MAP)
attributes = new HashMap<String, String>();
attributes.put(name, value);
}
public String getAttribute(String name) {
return attributes.get(name);
}
public String getNamespace() {
return namespace;
}
public String getElementName() {
return name;
}
public String toXML() {
StringBuilder buf = new StringBuilder();
buf.append("<").append(getElementName());
// TODO Xmlns??
if (getNamespace() != null) {
buf.append(" xmlns=\"").append(getNamespace()).append("\"");
}
for (String key : attributes.keySet()) {
buf.append(" ").append(key).append("=\"").append(StringUtils.escapeForXML(attributes.get(key))).append("\"");
}
buf.append("/>");
Log.e("&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&","&&&&&&&&&&&&&&&&&&&&&&&&&&&&=>"+buf.toString());
return buf.toString();
}
}
Run Code Online (Sandbox Code Playgroud)
基本上我通过看到聊天安全实现来获得这个想法,但它扩展了UnkownPacket而不是Packet.我从这里得到了帮助.
我也看过像这样的asmack的git分支,但是无法理解如何实现它.
如果您以任何方式使用chat secure,yaxim或任何其他Android XMPP客户端等库实现它,请提供帮助.
我无法为您提供解决方案,因为我遇到了类似的问题,但我可以从第二个链接告诉您 UnknownPacket 扩展了 Packet并实现了 PacketExtension,这就是为什么您必须在 return 语句中将 StreamHandlingPacket 转换为 (PacketExtension)你的 parseExtension 方法。
您能够捕获<enabled xmlns='urn:xmpp:sm:3' etc>
XMPP 服务器在发送时返回的 xml吗<enable xmlns='urn:xmpp:sm:3' etc>
?如果是这样,那将是您问题的开始。
让我们知道怎么回事!