1

我有一个关于在另一个 xml 中的 cdata 标记中解析 xml 的问题。我已经搜索过,但我没有找到我的确切问题。我发布示例:

<?xml version="1.0" encoding="UTF-8"?>
<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
  <S:Body>
    <ns2:CSResponse xmlns:ns2="http://webservices....../">
      <RespuestaVentaPrepagoTituloCS1>
        <ICallId>0</ICallId>
        <IResultCode>1</IResultCode>
        <SResulXML>
        <![CDATA[null<?xml version="1.0" encoding="UTF-8"?>
          <SS_prepagoCS version="0.1" fecha="2013-11-02T06:24:42" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation=".\SS_Pasdsd">
            <TTPSearchResult value="1" desc="OK">
              <TTPData xsi:nil="false">
                <SerialNumber>56676543243234</SerialNumber>
                ....

但我收到的回复是下一个:

<?xml version='1.0' encoding='UTF-8'?>
<S:Envelope xmlns:S="http://schemas.xmlsoap.org/soap/envelope/">
  <S:Body>
    <ns2:CS1Response xmlns:ns2="http://webservices..../">
      <RespuestaVentaPrepagoTituloCS1>
        <ICallId>0</ICallId>
        <IResultCode>1</IResultCode>
        <SResulXML>null&lt;?xml version="1.0" encoding="UTF-8"?>&lt;SS_prepagoCS version="0.1" fecha="2013-11-13T10:12:20" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation=".\SS_PrepagoCS_v0.1.xsd">  &lt;TTPSearchResult value="1" desc="OK">    &lt;TTPData xsi:nil="false">

而且我无法解析 cdata 的内容,因为 sax 解析器找不到 xml 标签。有人可以帮助我吗?

谢谢

编辑:添加更多代码

我提出要求:

    String data = "<?xml version=\"1.0\" encoding=\"UTF-8\"?> " + 
             "<soapenv:Envelope xmlns:soapenv=\"http://schemas.xmlsoap.org/soap/envelope/\" xmlns:web=\"http://webservices.sayp.bit.crtm/\"> " + 
             "   <soapenv:Header/> " + 
             "   <soapenv:Body> " + 
             ".... ";

    String action = "";
    HttpResponse res = sendRequest(serverV2 + method, data, action);

    if (res.getStatusLine().getStatusCode() == 200) {
        HttpEntity entity = res.getEntity();
        SAXParserFactory factory = SAXParserFactory.newInstance();
        SAXParser parser = factory.newSAXParser();
        CSHandler handler = new CSHandler();


        parser.parse(entity.getContent()), handler);//entity.getContent
        return handler.getResponse();
    }

在某些地方,我读到为下一个代码更改 entity.getContent() 应该可以工作,但结果是一样的。

        HttpEntity entity = res.getEntity();
        SAXParserFactory factory = SAXParserFactory.newInstance();
        SAXParser parser = factory.newSAXParser();
        CSHandler handler = new CSHandler();
        String xml=EntityUtils.toString(entity);
        if (BuildConfig.DEBUG)
            Log.i("XML", xml);
        parser.parse(new InputSource(new String(xml)), handler);//entity.getContent
        return handler.getResponse();
        }

而 CSHandler 是搜索标签的普通 SAX 解析器,但它无法找到标签,因为 xml 被转换为 html ......

4

1 回答 1

2

CDATA 部分中的文本或其他形式的转义文本可能相同,但由于转义或换行,解析器无法将其识别为 XML。

您需要做的是使用您的主解析器将所有这些文本转换为一个字符串,然后在至少去掉开头的“null”之后对该字符串中的 XML 开始一个单独的解析。

如果您发布 Java 代码以显示您当前如何解析 xml 的其余部分,我们也许能够提供有关处理此问题的更详细的指导。

于 2013-11-13T12:40:53.933 回答