解决UTF8+BOM编码xml文件解析异常

话说今天在做文件上传功能的时候,遇到了一个比较恶心的编码问题。这个问题导致dom4j无法解析xml字符串,在网上看了许久发现最简单的方式是用文本编辑器讲编码格式转换成UTF-8,有TX可能不知道,大多数编辑器的编码只有UTF-8,例如Windows自带的编辑器,但是像Notepad+一类的编辑器则可以看到更多的编码

请注意,默认的UTF-8的编码其实是UTF8+BOM,这个就是导致dom4j无法解析的原因。下面这个例子,大家看了就会明白了。

当我们读取一个以UTF-8+BOM编码的xml文件,并用dom4j直接进行解析的话会发生这样的尴尬

public static void main(String[] args) {
        File file = new File(Thread.currentThread().getContextClassLoader()
                .getResource("BOMEncodedFile.xml").getPath());
        try {
            InputStream inputStream = new FileInputStream(file);
            String fileContent = IOUtils.toString(inputStream, "UTF-8");
            Document document = DocumentHelper.parseText(fileContent);
            System.out.println(document.getRootElement().getName());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
当代码运行到第七行的时候,编译器会抛出

在反复查看文件,并确认文件内容正确无误的时候,我把文件内容一个一个的字符打印了出来,结果出现了红框这个鬼!!!

,我们比较一下以"UTF-8 without BOM"编码的xml文件时长什么样子的

结果一目了然,就是那个鬼导致了异常抛出。网上有很多解决办法,也有牛人给出了一个类去完美解决这个问题,我比较“懒”不想搞得那么麻烦,直接跳过这个不知道是什么鬼的字符就好了,代码如下

public static void main(String[] args) {
        File file = new File(Thread.currentThread().getContextClassLoader()
                .getResource("BOMEncodedFile.xml").getPath());
        try {
            InputStream inputStream = new FileInputStream(file);
            String fileContent = IOUtils.toString(inputStream, "UTF-8");
            char[] chars = fileContent.toCharArray();
            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < chars.length; i++) {
                //逐个打印字符对应的ascii编码
                System.out.println("第" + i + "个char的ascii码为:" + (byte) chars[i] + "    字符为:" + chars[i]);
                //跳过前面乱七八糟的字符
                if ((byte) chars[i] > 0) {
                    sb.append(chars[i]);
                }
            }
            Document document = DocumentHelper.parseText(sb.toString());
            System.out.println(document.getRootElement().getName());
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }


问题解决!

至于BOM是个什么鬼,大家有兴趣可以去搜搜看了解一下,这里就不赘述了。



  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值