invalid byte 1 of 1-byte UTF-8 sequence

在用SAX解析XML文档的时候,在XML文件中如果有中文的话就会抛出“invalid byte 1 of 1-byte UTF-8 sequence”异常,调试是总是找不到问题所在,于是求救于网络,终于找到问题所在,成功解决了问题,在此谢谢强大的网络资源。 

   XML内容实际是以UTF-8编码的,因此造成了包括中文字符的XML文件无法正常阅读,将编码格式改成“GB2312”后就可以正常解析了。<?xml   version="1.0"   encoding="GB2312"?> 



自己的总结: 
1、“org.dom4j.DocumentException: Invalid byte 1 of 1-byte UTF-8 sequence.”异常分析和解决: 
分析: 
该异常由下面的reader.read(file);语句抛出: 
SAXReader reader = new SAXReader(); 
Document doc = reader.read(file); 

产生这个异常的原因是: 
所读的xml文件实际是GBK或者其他编码的,而xml内容中却用<?xml version="1.0" encoding="utf-8"?>指定编码为utf-8,所以就报异常了! 

注释:参考网上的《Java/J2EE中文问题终极解决之道》一文,编码问题原因应该是:操作系统编码为GBK,而xml指定为utf-8,SAXReader使用系统的默认编码GBK,所以存在需要转换编码的问题,也就自然会出现乱码了!解决:让文件编码和java 操作该文件的接口的编码一致; 

解决: 
情况一:该xml文件由dom4j生成; 

解决方法:用 org.dom4j.io.XMLWriter xmlWriter = new org.dom4j.io.XMLWriter( 
                    new FileOutputStream(fileName)); 
代替 
xmlWriter = new XMLWriter(new FileWriter(fileName)); 
,指定编码为utf-8生成xml文件; 

详细参考资料1: 
Dom4j 编码问题彻底解决 作者:lonsen 
http://www.5inet.net/Develop/Java/036579,Dom4j_BianMaWenDiCheDeJieJue.aspx 

情况二:解析从jsp页面中读取到的用户输入的xml描述内容时,reader.read()抛出异常; 

解决方法: 
调用read前先把xml内容转为utf-8编码:(使用支持编码格式的函数) 

public void validate(FacesContext context, UIComponent component, Object obj) 
     throws ValidatorException { 
  
            String xmldescription = (String) obj; 
     byte[] bytes =xmldescription.getBytes(); 
            RelationXmlParser.isXmlOK("E://jiangcm//templateXMLSchema.xsd",bytes);  
     …… 
    } 

public static boolean isXmlOK(String xsdFile, byte[] tagetXml) throws SAXException,                  IOException, DocumentException 

   SAXReader reader = new SAXReader(); 
                …… 
   InputStream in = new ByteArrayInputStream(tagetXml); 
   InputStreamReader utf8In=new InputStreamReader(in,"utf-8"); 
                …… 
        } 



自己的解决:String.getBytes("utf-8") 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值