XML 中文问题

本文介绍了在使用SAXParser解析包含中文字符的XML文档时遇到的问题及解决方案。通过将XML文档转换为UTF-8编码,并使用正确的输入流类(如ByteArrayInputStream),可以有效避免乱码问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

起因:

     在使用SAXParser解析XML文档, 当XML文档中包含中文时出错.

解决方案:

       在对XML进行解析之前, 将String形式的XML文档, 都转换成UTF-8格式. 转换代码如下;

 public static String toUTF_8(final String str){
  if(str==null)
   return str;
   
  String retVal = str;
  try{
   retVal = new String(str.getBytes("ISO8859_1"), "UTF-8");
  } catch(Exception e){
   //log...
  }
  
  return retVal;
 }

续:

      今天发现问题的根本原因并不如下所述, 而是String转换成产生乱码, 使用的是StringBufferInputStream, 注意:这个类来能进行正确的编码转换, 使用ByteArrayInputStream, 代码如下:

   InputStream stream = null;
   try{
    stream = new ByteArrayInputStream(xml.getBytes("utf-8"));
   }catch (Exception e){
    
   }

相关链接:

http://www.vr-breeze.org/forum/archiver/?tid-67.html

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值