向openfire发送数据包 packet 获取返回数据 代码如下:
private void addOrgLinsterner() {
// XMPPConnection connection = SparkManager.getConnection();
// 注册IQProvider
ProviderManager.getInstance().addIQProvider("groups",
"http://pbc.gov.cn/nj/openfire/org", new GroupIQProvider());
SparkManager.getConnection().addPacketListener(new PacketListener() {
public void processPacket(Packet packet) {
if (packet instanceof IQ) {
IQ iq = (IQ) packet;
String packetID = iq.getPacketID();
// IQ装入等待MAP
System.out.println("装入WAITMAP:" + iq.toXML());
WaitMap.put(packetID, iq.toXML());
}
}
}, new PacketFilter() {
public boolean accept(Packet arg0) {
if (arg0 instanceof IQ) {
if (arg0.toXML().contains(
"http://pbc.gov.cn/nj/openfire/org")) {
return true;
} else {
//System.out.println(arg0.toXML());
return false;
}
} else {
//System.out.println(arg0.toXML());
return false;
}
}
});
}
其中:1、new PacketFilter() 这是一个过滤器
2、 WaitMap.put(packetID, iq.toXML())是将获取到的数据取出
(
WaitMap代码如下:
public class WaitMap {
private static Map waitMap = new HashMap();
private static Map timeMap = new HashMap();
public static void put(Object key, Object value){
long now = System.currentTimeMillis();
//System.out.println(value);
timeMap.put(key,now);
waitMap.put(key, value);
}
public static Object get(Object key){
//返回Object,如果为空,等待10秒
long startTime = System.currentTimeMillis();
while(waitMap.get(key) == null){
long nowTime = System.currentTimeMillis();
if ((nowTime - startTime) >= 10000) {
break;
}
}
Object value = waitMap.get(key);
waitMap.remove(key);
timeMap.remove(key);
//删除超时Object
deleteTimeoutObject();
return value;
}
private static void deleteTimeoutObject(){
//时间线,当前时间的10秒前
long timeline = System.currentTimeMillis() - 10000;
Iterator it = timeMap.entrySet().iterator();
while (it.hasNext()) {
Map.Entry entry = (Map.Entry) it.next();
if(Long.valueOf(entry.getValue().toString()) <= timeline){
Object key = entry.getKey();
waitMap.remove(key);
timeMap.remove(key);
}
}
}
}
)
private void addOrgLinsterner() {
// XMPPConnection connection = SparkManager.getConnection();
// 注册IQProvider
ProviderManager.getInstance().addIQProvider("groups",
"http://pbc.gov.cn/nj/openfire/org", new GroupIQProvider());
SparkManager.getConnection().addPacketListener(new PacketListener() {
public void processPacket(Packet packet) {
if (packet instanceof IQ) {
IQ iq = (IQ) packet;
String packetID = iq.getPacketID();
// IQ装入等待MAP
System.out.println("装入WAITMAP:" + iq.toXML());
WaitMap.put(packetID, iq.toXML());
}
}
}, new PacketFilter() {
public boolean accept(Packet arg0) {
if (arg0 instanceof IQ) {
if (arg0.toXML().contains(
"http://pbc.gov.cn/nj/openfire/org")) {
return true;
} else {
//System.out.println(arg0.toXML());
return false;
}
} else {
//System.out.println(arg0.toXML());
return false;
}
}
});
}
其中:1、new PacketFilter() 这是一个过滤器
2、 WaitMap.put(packetID, iq.toXML())是将获取到的数据取出
(
WaitMap代码如下:
public class WaitMap {
private static Map waitMap = new HashMap();
private static Map timeMap = new HashMap();
public static void put(Object key, Object value){
long now = System.currentTimeMillis();
//System.out.println(value);
timeMap.put(key,now);
waitMap.put(key, value);
}
public static Object get(Object key){
//返回Object,如果为空,等待10秒
long startTime = System.currentTimeMillis();
while(waitMap.get(key) == null){
long nowTime = System.currentTimeMillis();
if ((nowTime - startTime) >= 10000) {
break;
}
}
Object value = waitMap.get(key);
waitMap.remove(key);
timeMap.remove(key);
//删除超时Object
deleteTimeoutObject();
return value;
}
private static void deleteTimeoutObject(){
//时间线,当前时间的10秒前
long timeline = System.currentTimeMillis() - 10000;
Iterator it = timeMap.entrySet().iterator();
while (it.hasNext()) {
Map.Entry entry = (Map.Entry) it.next();
if(Long.valueOf(entry.getValue().toString()) <= timeline){
Object key = entry.getKey();
waitMap.remove(key);
timeMap.remove(key);
}
}
}
}
)