java – 为什么org.apache.xerces.parsers.SAXParser不会跳过utf8编码的xml中的BOM?

我有一个带utf8编码的xml.
文件包含BOM作为文件的开头.
所以在解析过程中我遇到了org.xml.sax.SAXParseException:prolog中不允许使用内容.
我无法从文件删除这3个字节.
我无法将文件加载到内存中并在此处删除它们(文件很大).
因此,出于性能原因,我正在使用SAX解析器,如果它们在“”标记之前存在,则只想跳过这3个字节.
我应该为此继承InputStreamReader吗?

我是java的新手 – 请告诉我正确的方法.

解决方法

这已经出现了,当我遇到它时,我在Stack Overflow上发现了 the answer.链接的答案使用pushbackinputstream来测试BOM.

相关文章

应用场景 C端用户提交工单、工单创建完成之后、会发布一条工...
线程类,设置有一个公共资源 package cn.org.chris.concurre...
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量