获取webservice接⼝数据解析出现异常处理
org.dom4j.DocumentException: Error on line 1 of document : Content is not allowed in prolog. Nested exception: Content is not allowed in prolog.
at org.dom4j.ad(SAXReader.java:482)
at org.dom4j.DocumentHelper.parseText(DocumentHelper.java:278)
.....
Nested exception:
....
⽹上所述总结来说就是 解析内容内包含BOM 。这个标记是看不到的,流⾥⾯有这个标记⽽已。
BOM:Byte Order Mark,中⽂名字节顺序标记。UCS规范建议在传输字节流前,先传输BOM来判断字节顺序。
其实UTF-8是不需要⽤BOM来表明字节顺序的,但是可以 ⽤BOM来表明编码⽅式。BOM的UTF-8编码是EF BB BF,所以呢,如果接受者收到EF BB BF开头的字节流,就说明它是UTF-8编码了。
解决办法:
如果解析的是⽂件 :
可以⽤UltraEdit或者EmEditor打开XML,然后另存为,保存的时候有选项是以⽆BOM的UTF-8保存还是以有BOM的UTF-8保存。
如果是从远程请求回来的内容:
那么你把返回的流New为字符串,是看不到BOM的,但是你必须截取你需要的内容:
if(null != result && !"".equals(result)){
使用dom4j解析xml文件if(result.indexOf("<") != -1 && result.lastIndexOf(">") != -1 && result.lastIndexOf(">") > result.indexOf("<"))
result = result.substring(result.indexOf("<"), result.lastIndexOf(">") + 1);
}
也有说是DOM4J版本较低引起的,但是我看了⼀下我是⽤的版本是1.6.1,所以排除此类可能,但是在实际中我还是建议使⽤最新稳定版本来进⾏开发。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论