我有一个关于在另一个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<?xml version="1.0" encoding="UTF-8"?><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"> <TTPSearchResult value="1" desc="OK"> <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 ......
答案 0 :(得分:2)
CDATA部分中的文本或其他表单中的转义文本可能相同,但由于转义或换行,解析器无法将其识别为XML。
您需要做的是使用主解析器将所有这些文本转换为字符串,然后在该字符串的开头至少剥离“null”之后为该字符串中的XML启动一个单独的解析
如果您发布Java代码,显示您当前正在解析xml的其余部分,我们可能能够提供有关处理此问题的更详细指导。