Java处理文件BOM头的方式推荐

背景:

java普通的文件读取方式对于bom是没法正常识别的。html

   使用普通的InputStreamReader,若是采用的编码正确,那么能够得到正确的字符,但bom仍然附带在结果中,很容易致使数据处理出错。
另外,对于存在BOM头的文件,没法猜想它使用的编码。
java

目标:

实现一种方式,可对BOM头进行捕捉和过滤apache


解决方案有二:

1、  使用apache的工具类,以BOMStream为例:api

    BOMStream,api参考:http://commons.apache.org/io/apidocs/org/apache/commons/io/input/BOMInputStream.html函数

 该类的构造方式: BOMInputStream bomIn = new BOMInputStream(in) //仅能检测到UTF8的bom,且在流中exclude掉bom
 BOMInputStream bomIn = new BOMInputStream(in, include); //同上,且指定是否包含
 也能够指定检测多种编码的bom,但目前仅支持UTF-8/UTF-16LE/UTF-16BE三种,对于UTF32之类不支持。 BOMInputStream bomIn = new BOMInputStream(in, ByteOrderMark.UTF_16LE, ByteOrderMark.UTF_16BE); 有用的方法: bomIn.hasBOM()、hasBOM(ByteOrderMask.**)可用于判断当前流中是否检测到了bom。



   读取文件示例:工具

FileInputStream fis = new FileInputStream(file); //可检测多种类型,并剔除bom
   BOMInputStream bomIn = new BOMInputStream(in, false,ByteOrderMark.UTF-8, ByteOrderMark.UTF_16LE, ByteOrderMark.UTF_16BE); String charset = "utf-8"; //若检测到bom,则使用bom对应的编码
   if(bomIn.hasBOM()){ charset = bomIn.bs.getBOMCharsetName(); } InputStreamReader reader = new InputStreamReader(bomIn, charset); ...

 

2、使用一个更强大点的工具类(能够支持UTF-8/UTF-16LE/UTF-16BE/UTF-32LE/UTF-32BE):
       编码

   参考地址:http://koti.mbnet.fi/akini/java/unicodereader/, 下载其中两个文件:UnicodeStream和UnicodeReaderspa

   以UnicodeReader为例:.net

FileInputStream fis = new FileInputStream(file); UnicodeReader ur = new UnicodeReader(fis, "utf-8"); BufferedReader br = new BufferedReader(ur); ...

 

   相较于Apache的工具类,这里的UnicodeReader 支持更多的BOM编码。code

   源码解读:

   UnicodeReader 经过PushbackInputStream+InputStreamReader实现BOM的自动检测和过滤读取;

   当没有检测到BOM时,pushback流将回退,并采用构造函数传入的编码进行读取。
   不然使用BOM对应的编码进行读取。

   

  相对来讲,第二种方式更加轻量和强大;另外也更加透明,能够随便修改源码来实现本身的需求。

 

原文地址:http://blog.csdn.net/littleatp2008/article/details/6943215

相关文章
相关标签/搜索