文件类型识别的方法有很多,例如使用URLConnection对象的getContentType方法获得:
其他方法可参考资料:[url]http://www.rgagnon.com/javadetails/java-0487.html[/url]中介绍的方法针对不同形式的数据进行解析。
若数据是字节数组时,可参考程序:
上面的程序需要jmimemagic-0.1.0.jar包支持,见附件
文件识别简单介绍:
一般来说有两种途径识别文件的类型:
1.通过文件的扩展名识别,这种方式能对文件进行简单直观的判别,不能进行本质性的判别,一旦文件扩展名被修改了,就会判断失误;
2.通过文件数据的头部分进行识别,主流文件都在文件头记录了一些特征信息,可以利用这些特征信息对文件类型进行判别,这种方式较为本质些,可信度较高。
谈到第二中方式,有两种常见实现方法,第一种:读取文件头信息,下载文件类型特制信息映射表,拿头信息和映射表进行匹配,可以得到常见文件类型信息;第二种:不用自己去匹配信息,而是采用第三方提供现成的包来解析文件类型,这样能节省很多时间,上面介绍的就是这种方法。
File file = new File(“文件路径”);
String type = file.toURL().openConnection().getContentType();
其他方法可参考资料:[url]http://www.rgagnon.com/javadetails/java-0487.html[/url]中介绍的方法针对不同形式的数据进行解析。
若数据是字节数组时,可参考程序:
/**
* 根据图片的bits字节数组中的数据,识别图片文件类型,再根据prefix内容构造一个适当的文件名称
* @param bits 图片字节数组
* @param prefix 用于构造文件名称的前缀串
* @return 0元素存放文件名称,1元素存放文件类型
*/
public static String [] imgBitsDeal(byte[]bits, String prefix){
String [] rt = new String[2];
// snippet for JMimeMagic lib
// http://sourceforge.net/projects/jmimemagic/
Magic parser = new Magic() ;
MagicMatch match = null;
try {
match = parser.getMagicMatch(bits);
rt[1] = match.getMimeType();//文件类型
rt[0] = prefix + "." + match.getExtension();//构造文件名称(含扩展名)
// System.out.println(match.getMimeType()) ;
// System.out.println(match.getExtension()) ;
} catch (Exception e) {
// TODO Auto-generated catch block
rt[0] = prefix + "." + "png"; //默认文件名
rt[1] = "image/png"; //默认文件类型
e.printStackTrace();
}
return rt;
}
上面的程序需要jmimemagic-0.1.0.jar包支持,见附件
文件识别简单介绍:
一般来说有两种途径识别文件的类型:
1.通过文件的扩展名识别,这种方式能对文件进行简单直观的判别,不能进行本质性的判别,一旦文件扩展名被修改了,就会判断失误;
2.通过文件数据的头部分进行识别,主流文件都在文件头记录了一些特征信息,可以利用这些特征信息对文件类型进行判别,这种方式较为本质些,可信度较高。
谈到第二中方式,有两种常见实现方法,第一种:读取文件头信息,下载文件类型特制信息映射表,拿头信息和映射表进行匹配,可以得到常见文件类型信息;第二种:不用自己去匹配信息,而是采用第三方提供现成的包来解析文件类型,这样能节省很多时间,上面介绍的就是这种方法。