dom4j解析xml错误记录

最近在使用dom4j直接解析从远程发送过来的xml文件时,在使用dom4j读取输入流时出现了一些字符编码的错误。

源码如下:public void checkXML1(InputStream input){

       SAXReader reader = new SAXReader();//input为从远程发送过来的输入流

        Document doc = null;

        try {

            doc = reader.read(input);//这个出现字符编码错误

            StringWriter buffer = new StringWriter();

            OutputFormat format = new OutputFormat();

            format.setEncoding("UTF-8");

            format.setIndentSize(4);

            format.setNewlines(true);

            format.setTrimText(true);

            format.setExpandEmptyElements(true);

            HTMLWriter writer = new HTMLWriter(buffer,format);

            writer.write(doc);

            String xml = buffer.toString();

            System.out.println("xml:"+xml);

        } catch (DocumentException e) {

            e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.

        } catch (IOException e) {

            e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.

        }

    }

错误具体信息如下:org.dom4j.DocumentException: Invalid byte 1 of 1-byte UTF-8 sequence. Nested exception: Invalid byte 1 of 1-byte UTF-8 sequence.有时会出现说文档中有(Unicode oxb2)编码错误。

解决办法:使用InputStreamReader包装此input输入流,源码如下:InputStreamReader inputReader = new InputStreamReader(input,"gbk");//对输入流进行转换成相应的编码就可以了。修改后的源码如下:public void checkXML1(InputStream input){

       SAXReader reader = new SAXReader();

        Document doc = null;

        try {

            InputStreamReader inputReader = new InputStreamReader(input,"gbk"); //编码转换

            doc = reader.read(inputReader );

            StringWriter buffer = new StringWriter();

            OutputFormat format = new OutputFormat();

            format.setEncoding("UTF-8");

            format.setIndentSize(4);

            format.setNewlines(true);

            format.setTrimText(true);

            format.setExpandEmptyElements(true);

            HTMLWriter writer = new HTMLWriter(buffer,format);

            writer.write(doc);

            String xml = buffer.toString();

            System.out.println("xml:"+xml);

        } catch (DocumentException e) {

            e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.

        } catch (IOException e) {

            e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.

        }

    }

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值