`
齐晓威_518
  • 浏览: 618181 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

Java根据文件头获取文件类型

 
阅读更多
    文件头是位于文件开头的一段承担一定任务的数据,一般都在开头的部分。头文件作为一种包含功能函数、数据接口声明的载体文件,用于保存程序的声明(declaration),而定义文件用于保存程序的实现 (implementation)。
      为了解决在用户上传文件的时候在服务器端判断文件类型的问题,故用获取文件头的方式,直接读取文件的前几个字节,来判断上传文件是否符合格式。具体代码如下:

package com.test.day11.io;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.HashMap;

/**
* 获取和判断文件头信息
*
* @author bigbird
*
*/
public class FileType {

//缓存文件头信息-文件头信息
public static final HashMap<String, String> mFileTypes = new HashMap<String, String>();

static {
// images
mFileTypes.put("FFD8FF", "jpg");
mFileTypes.put("89504E47", "png");
mFileTypes.put("47494638", "gif");
mFileTypes.put("49492A00", "tif");
mFileTypes.put("424D", "bmp");
//
mFileTypes.put("41433130", "dwg"); // CAD
mFileTypes.put("38425053", "psd");
mFileTypes.put("7B5C727466", "rtf"); // 日记本
mFileTypes.put("3C3F786D6C", "xml");
mFileTypes.put("68746D6C3E", "html");
mFileTypes.put("44656C69766572792D646174653A", "eml"); // 邮件
mFileTypes.put("D0CF11E0", "doc");
mFileTypes.put("5374616E64617264204A", "mdb");
mFileTypes.put("252150532D41646F6265", "ps");
mFileTypes.put("255044462D312E", "pdf");
mFileTypes.put("504B0304", "docx");
mFileTypes.put("52617221", "rar");
mFileTypes.put("57415645", "wav");
mFileTypes.put("41564920", "avi");
mFileTypes.put("2E524D46", "rm");
mFileTypes.put("000001BA", "mpg");
mFileTypes.put("000001B3", "mpg");
mFileTypes.put("6D6F6F76", "mov");
mFileTypes.put("3026B2758E66CF11", "asf");
mFileTypes.put("4D546864", "mid");
mFileTypes.put("1F8B08", "gz");
mFileTypes.put("", "");
mFileTypes.put("", "");
}

/**
* 根据文件路径获取文件头信息
*
* @param filePath
*            文件路径
* @return 文件头信息
*/
public static String getFileType(String filePath) {
return mFileTypes.get(getFileHeader(filePath));
}

/**
* 根据文件路径获取文件头信息
*
* @param filePath
*            文件路径
* @return 文件头信息
*/
public static String getFileHeader(String filePath) {
FileInputStream is = null;
String value = null;
try {
is = new FileInputStream(filePath);
byte[] b = new byte[4];
is.read(b, 0, b.length);
value = bytesToHexString(b);
} catch (Exception e) {
} finally {
if (null != is) {
try {
is.close();
} catch (IOException e) {
}
}
}
return value;
}

         /**
* 根据文对象获取文件头信息
*
* @param filePath
*            文件路径
* @return 文件头信息
*/
public static String getFileHeader(fileFile filePath) {
InputStream is = null;
String value = null;
try {
is = new InputStream(filePath);
byte[] b = new byte[4];
is.read(b, 0, b.length);
value = bytesToHexString(b);
} catch (Exception e) {
} finally {
if (null != is) {
try {
is.close();
} catch (IOException e) {
}
}
}
return value;
}


/**
* 将要读取文件头信息的文件的byte数组转换成string类型表示
*
* @param src
*            要读取文件头信息的文件的byte数组
* @return 文件头信息
            *下面这段代码就是用来对文件类型作验证的方法,
             第一个参数是文件的字节数组,第二个就是定义的可通过类型。代码很简单,         主要是注意中间的一处,将字节数组的前四位转换成16进制字符串,并且转换的时候,要先和0xFF做一次与运算。这是因为,整个文件流的字节数组中,有很多是负数,进行了与运算后,可以将前面的符号位都去掉,这样转换成的16进制字符串最多保留两位,如果是正数又小于10,那么转换后只有一位,需要在前面补0,这样做的目的是方便比较,取完前四位这个循环就可以终止了。
*/
private static String bytesToHexString(byte[] src) {
StringBuilder builder = new StringBuilder();
if (src == null || src.length <= 0) {
return null;
}
String hv;
for (int i = 0; i < src.length; i++) {
// 以十六进制(基数 16)无符号整数形式返回一个整数参数的字符串表示形式,并转换为大写
hv = Integer.toHexString(src[i] & 0xFF).toUpperCase();
if (hv.length() < 2) {
builder.append(0);
}
builder.append(hv);
}
return builder.toString();
}

public static void main(String[] args) throws Exception {
final String fileType = getFileType("E:/读书笔记/Java编程思想读书笔记.docx");
System.out.println(fileType);
}
}

为什么只取前四位,不是六位或八位呢?这是因为,大象根据反复测试发现,从第五位开始到第八位,同一种类型的文件,在这几位里面很有一些存在区别,像图片以及pdf,这种现象很多,为了避免同一类型的文件,因为这一些小的不同,要定义N多检测头信息,这样做似乎没有必要,因此大象才建议取前四位作为类型检测的依据

注意:读取TXT文件时,不能用上述方法,因为文本文件不是二进制,则需要单独判断
分享到:
评论
2 楼 齐晓威_518 2015-01-04  
呵呵,里面有个测试用例,自己可以将相应的文件类型编码计算出来
1 楼 h191561957 2014-12-31  
判断不是太准
xlsx被断为docx
pdf也不对


相关推荐

    Android中Java根据文件头获取文件类型的方法

    本文将详细介绍一种在Android中使用Java根据文件头获取文件类型的实现方法。这个方法创建了一个名为`FileType`的类,其中包含一个`HashMap`用来存储不同文件类型与其对应的文件头信息。以下是一些常见文件类型的文件...

    java实现上传文件类型检测过程解析

    * 根据文件路径获取文件头信息 * * @param filePath 文件路径 * @return 文件头信息 */ public static String getFileType(String filePath) { String type = getFileHeader(filePath); System.out.println...

    java截取wave文件,java获取wave文件头信息

    这是一个完整的myeclipse项目,主要实现的功能有: 1.用java获取wave类型的音频文件头信息; 2.根据传入参数截取指定时间段内的音频片段 改资源为本人原创,下载后导入myeclipse可以直接运行

    JAVA100例之实例91 通过解析客户发送的文件头,获取客户信息

    4. **解析文件头**:根据已知的文件头格式,分析读取到的字节序列,以确定文件类型或提取用户信息。这一步可能涉及二进制数据的转换和字符串的比较。 ```java String headerString = new String(headerBytes, ...

    Java实现的获取和判断文件头信息工具类用法示例

    本文主要介绍了Java实现的获取和判断文件头信息工具类的用法示例,该工具类可以根据文件路径获取文件头信息,并根据头信息判断文件类型。下面是该工具类的详细分析和相关操作技巧。 首先,我们需要了解文件头信息的...

    图片文件上次,获取图片文件实际类型

    * Discription:[getAllFileType,常见文件头信息] */ static{ IMG_FILE_TYPE_MAP.put("jpg", "FFD8FF"); // JPEG (jpg) IMG_FILE_TYPE_MAP.put("jpeg", "FFD8FF"); IMG_FILE_TYPE_MAP.put("png", ...

    如何使用Java代码获取播放文件的时长

    首先,对于不同类型的文件,获取时长的方法会有所不同。例如,音频文件(如mp3)和视频文件(如mp4)的处理方式就有所区别。对于音频文件,我们通常需要解析音频头部信息来获取时长;对于视频文件,可能需要解析容器...

    java获取文件编码(判断有无BOM)

    本文将详细介绍如何在Java中获取文件的编码并判断文件是否带有BOM。 首先,让我们了解一下什么是BOM。BOM是UTF-8、UTF-16和UTF-32等编码格式中的一个可选标记,用于告知解析器文件的编码类型。例如,UTF-8的BOM是三...

    SpringBoot文件上传控制及Java 获取和判断文件头信息

    2. Java 获取和判断文件头信息:如何使用 Java 语言来获取和判断文件头信息,包括如何使用 MultipartFile 对象来获取文件信息,以及如何判断文件的类型和大小等信息。 3. Ajax 文件上传:如何使用 Ajax 方式上传文件...

    java验证文件真实格式和编码格式工具类

    这个主题主要涉及两个核心工具类:`VerifyFileType.java` 和 `VerifyFileEncoder.java`,它们分别用于验证文件的类型和编码。接下来,我们将详细讨论这两个方面。 ### 文件类型验证 `VerifyFileType.java` 类很...

    Java获取文件的类型和扩展名的实现方法

    总的来说,Java中获取文件类型和扩展名的方式主要包括使用`File`类获取文件名和扩展名,以及通过探测MIME类型或读取文件头来判断文件类型。实际开发中,应根据具体需求选择合适的方法。注意,确保在处理用户提供的...

    JAVA获取本地视频或者网络URL的时长.zip

    总的来说,获取视频时长需要对Java的文件I/O、网络请求以及多媒体处理有一定的了解。使用合适的库可以简化这个过程,提高效率。在实际应用中,确保处理的健壮性和效率是非常重要的,例如处理网络延迟、错误重试等。

    java解析Pcap文件获取五元组(可执行)

    根据数据包的类型,你可以进行相应的转换。 ```java if (packet instanceof IPacket) { IPacket ipPacket = (IPacket) packet; String sourceIP = ipPacket.src_ip.toString(); String destIP = ipPacket.dst_...

    java根据IP获取城市代码

    这篇博客“java根据IP获取城市代码”可能探讨了如何利用Java来解决这个问题。 首先,我们需要了解IP地址和城市代码的关系。IP地址是互联网上设备的唯一标识,由四段数字组成,每段之间用点分隔。城市代码通常指的是...

    获取文件类型.rar

    总的来说,获取文件类型的方法包括但不限于:检查文件扩展名、读取文件头信息、使用系统命令或特定库解析内容。根据实际需求和环境,选择合适的方法来实现文件类型的识别。在处理用户上传的文件时,一定要注意安全性...

    Java 上传文件到 SharePoint

    4. 将文件内容添加到MultipartEntityBuilder,设置文件名和内容类型。 5. 设置“overwrite”参数,决定是否覆盖已存在的同名文件。 6. 将构建好的MultipartEntity设置到HttpPost对象。 7. 执行HttpPost请求并处理...

    读取aac文件头信息

    在读取AAC文件头时,我们需要确保缓冲区包含足够的数据来解析文件头,这可能需要多次调用`fill_buffer`以获取完整的信息。文件头通常位于文件的开始部分,包含了编码格式、帧长度、采样率、位深度等重要信息。 然后...

    Java多个文件根据URL下载后打包zip导出.zip

    总结来说,"Java多个文件根据URL下载后打包zip导出"涉及的技术主要包括:网络请求、文件I/O、文件打包、HTML交互以及异步处理。理解这些知识点,可以帮助开发者构建一个功能完备的文件下载和打包系统。

    使用Java获取HTTP头信息

    在Java编程中,获取HTTP头信息是网络编程中常见的任务,尤其在开发Web应用程序或进行API交互时。HTTP头信息包含了许多关于请求或响应的重要元数据,如服务器信息、编码格式、Cookie等。本篇文章将深入讲解如何使用...

Global site tag (gtag.js) - Google Analytics