欲推任意XMLEncoded Java对象来回使用道场的cometd通道和I有一个问题正确解码的有效负载。

为了做到这一点我在聊天室的客户端演示程序的精简版本的发送方法:

private void send(String string) {
  Map<String, Object> map = new HashMap<String, Object>();
  map.put("intArray", new int[] {1});

  ByteArrayOutputStream baos = new ByteArrayOutputStream();
  XMLEncoder xmlEncoder = new XMLEncoder(baos);
  xmlEncoder.writeObject(map);
  xmlEncoder.close();
  Map<String, Object> encodedMap = new HashMap<String, Object>();
  try {
    String encoded = baos.toString("UTF-8");
    encodedMap.put("xmlpayload", encoded);
  } catch (Exception e) {
   throw new RuntimeException("could not use UTF-8", e);
  } 
  bayreuxClient.publish("/prototype/a", encodedMap, String.valueOf(System.currentTimeMillis()));
}

这对于现在创建扁平化到一个UTF-8编码的字节流(我知道我需要照顾编码过,但现在不是问题)。

一个XML片段

在消息监听器接受这看起来像:

listener = new MessageListener() {
  @Override
  public void deliver(Client fromClient, Client toClient, Message msg) {
    if (!_connected) {
      _connected = true;
      synchronized (this) {
      this.notify();
    }
  }
  Object data = msg.getData();
  if (data instanceof Map) {
    Map map = (Map) data;
    Object rawPayload = map.get("xmlpayload");
    if (rawPayload instanceof String) {
      System.out.println("xmlpayload = " + rawPayload);
      ByteArrayInputStream bais;
      try {
        String xmlPayload = ((String) rawPayload).replaceAll("&gt;",">").replaceAll("&lt;", "<").replaceAll("&amp;","&");
        bais = new ByteArrayInputStream(xmlPayload.getBytes("UTF-8"));
        XMLDecoder xmlDecoder = new XMLDecoder(bais);
        Object o = xmlDecoder.readObject();
        xmlDecoder.close();
        System.out.println(">> decoded payload=" + o + ", class=" + o.getClass());
      } catch (UnsupportedEncodingException e) {
        throw new RuntimeException("no UTF-8", e);
      }
     }
   }
  }
 };
 address = new Address("localhost", 8080);
 bayreuxClient = new BayeuxClient(httpClient, address, "/cometd/cometd");
 bayreuxClient.addListener(listener);

正如你可以看到我已经通过反复试验发现,发送的字符串有其不足,大于,&符保护我,然后取消保护,并呼吁了xmlDecode。

的输出是:

xmlpayload = &lt;?xml version="1.0" encoding="UTF-8"?&gt; 
&lt;java version="1.6.0_16" class="java.beans.XMLDecoder"&gt; 
 &lt;object class="java.util.HashMap"&gt; 
  &lt;void method="put"&gt; 
   &lt;string&gt;intArray&lt;/string&gt; 
   &lt;array class="int" length="1"&gt; 
    &lt;void index="0"&gt; 
     &lt;int&gt;1&lt;/int&gt; 
    &lt;/void&gt; 
   &lt;/array&gt; 
  &lt;/void&gt; 
 &lt;/object&gt; 
&lt;/java&gt; 

>> decoded payload={intArray=[I@2f1e75}, class=class java.util.HashMap

所以它是可逆的。我有把这些字符字符串对象是XMLEncoded / XMLDecoded内的实验并不好 - 他们都不是双proctected - 所以我的野蛮解码也影响了他们

现在的问题是:什么是正确的方式将这些字符串解码?是否有一个JSON库我需要使用的,而不是我的快速和肮脏的代码?我可能击中了错误的Java客户端库的cometd?

(注:我已使用的cometd-1.0.0rc0库这个实验)


编辑:原来,通信通过在同一个网络服务器一个比另一个部署碰巧我的认为的花的cometd通信的关怀和的的部署包含过滤器以.json该做的XML保护。

http://groups.google.com/group/cometd -users / browse_thread /线程/ 6fbdaae669e5f9d3

在换句话说我的代码以外的配置问题。希望修订的部署将解决这个问题。

有帮助吗?

解决方案

用来UNESCAPE XML最好库是阿帕奇百科全书郎,

   StringEscapeUtils.unescapeXml();

看起来这是在你使用的贝叶Java客户端的错误。它的编码/解码不是对称的。我打算使用它。现在,我会三思而后行:)

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top