微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

XML格式的报文返回给浏览器出现的问题

鉴于本片博文是访问量最大的一篇,特此对本文进行针对性修订,希望可以帮到更多的人!

在使用FirefoxChrome、IE测试获取xml格式数据文件时,会遇到如下错误

Firefox浏览器提示错误如下:
XML解析错误:未组织好
位置:http://localhost:8080/app/interfaceService/getCustomerGroup.service
行:1,列:16535:
-----------------------------------------^

谷歌Chrome浏览器提示错误如下:

This page contains the following errors:

error on line 1 at column 16526: EntityRef: expecting ';'

Below is a rendering of the page up to the first error.

IE浏览器错误如下:

<ftpPassword>null</ftpPassword>
无法显示 XML 页。

无法查看使用 XSL 样式表的 XML 输入。请更正错误然后单击刷新 按钮,或稍后重试。

要求分号。处理资源 'http://localhost:8080/app/***.service' 时出错。第 1 行,位置: 4389

----------------------------------------------------------------------------

----------------------------------------------------------------------------

分析上述问题的原因:
Firefox浏览器、谷歌Chrome浏览器以及大多数浏览器在显示xml文件时,显示的并不是文件源码,而是经过“xml解析器”解析后的结果。但是,“xml解析器”在遇到字符“&”时,会把“&”当做一个实体引用的开始,而去寻找这个实体引用的结束符号“;”,本文上面遇到的就是这个问题。
xml文档中,像“&”这样的预定义的实体引用一共有5个,分别是“&”、“<”、“>”、“'”、“"”。
解决方法一:
把实体引用编码后使用,即
把“&”编码为 “&amp;
把“<”编码为“&lt;
把“>”编码为 “&gt;
把“'”编码为 “&apos;
把“"”编码为 “&quot;
针对本文上面的问题,即把原来代码中的这些字符转义;

解决方法二:
标记CDATA中,所有的标记、实体引用都被忽略,而被“xml解析器”一视同仁地当做原始字符数据看待,CDATA的形式如下:<![CDATA[文本内容]]>
针对本文上面的问题,即把原来代码中的:

使用CDATA需要注意的两点,一:由于CDATA的结束符号是“]]>”,所以CDATA中不能包含“]]>”,二:由于CDATA中的所有标记、实体引用都被忽略,所以CDATA不能嵌套使用。

如有兴趣获取更多资料:加下求:378437335

原文地址:https://www.jb51.cc/xml/300509.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。