鉴于本片博文是访问量最大的一篇,特此对本文进行针对性修订,希望可以帮到更多的人!
在使用Firefox、Chrome、IE测试获取xml格式数据文件时,会遇到如下错误:
Firefox浏览器提示的错误如下:
XML解析错误:未组织好
位置:http://localhost:8080/app/interfaceService/getCustomerGroup.service
行:1,列:16535:
-----------------------------------------^
This page contains the following errors:
Below is a rendering of the page up to the first error.
IE浏览器错误如下:
无法查看使用 XSL 样式表的 XML 输入。请更正错误然后单击刷新 按钮,或稍后重试。
要求分号。处理资源 'http://localhost:8080/app/***.service' 时出错。第 1 行,位置: 4389
----------------------------------------------------------------------------
分析上述问题的原因:
Firefox浏览器、谷歌Chrome浏览器以及大多数浏览器在显示xml文件时,显示的并不是文件源码,而是经过“xml解析器”解析后的结果。但是,“xml解析器”在遇到字符“&”时,会把“&”当做一个实体引用的开始,而去寻找这个实体引用的结束符号“;”,本文上面遇到的就是这个问题。
在xml文档中,像“&”这样的预定义的实体引用一共有5个,分别是“&”、“<”、“>”、“'”、“"”。
解决方法一:
把实体引用编码后使用,即
把“&”编码为 “&”
把“<”编码为“<”
把“>”编码为 “>”
把“'”编码为 “'”
把“"”编码为 “"”
针对本文上面的问题,即把原来代码中的这些字符转义;
解决方法二:
在标记CDATA中,所有的标记、实体引用都被忽略,而被“xml解析器”一视同仁地当做原始字符数据看待,CDATA的形式如下:<![CDATA[文本内容]]>
针对本文上面的问题,即把原来代码中的:
使用CDATA需要注意的两点,一:由于CDATA的结束符号是“]]>”,所以CDATA中不能包含“]]>”,二:由于CDATA中的所有标记、实体引用都被忽略,所以CDATA不能嵌套使用。
如有兴趣获取更多资料:加下求:378437335