我正在使用SAX解析器(在android上)从WebService解析xml文件.在某些元素上,CDATA被截断且未完成,例如XML文件包含类似
<name><![CDATA[Gölsder und Ginck GmbH]]></name>
并在解析xml文件之后
public void characters(char[] ch, int start, int length)
throws SAXException {
super.characters(ch, start, length);
String text = new String(ch, start, length);
文本仅包含“Gölsderund Gin”(前15个字符).我用eclipse调试了它,发现整个字符串不包含在该方法的“ char [] ch”参数中.所以解析本身似乎有一个错误
解决方法:
我也有这个问题.事实是,可以在同一元素上多次调用character()方法.就您而言,如果要编写此代码:
public void characters(char[] ch, int start, int length)
throws SAXException {
super.characters(ch, start, length);
String text = new String(ch, start, length);
Log.d("XMLTEST", text);
}
您可能会收到两个日志消息,一个是Gölsderund Gin,另一个是ck GmbH.
总之,在接收新字符时,需要具有连接的成员变量.