- 浏览: 618175 次
- 性别:
- 来自: 郑州
文章分类
最新评论
-
AlanKay:
Mart_dai 写道Hi 齐晓威_518,我想问问,在exc ...
java 后台 Excel 文件生成后转化为字节流 -
18335864773:
国内的pageoffice插件也可以生成excel。也可以用流 ...
java 后台 Excel 文件生成后转化为字节流 -
JAVA_CLASSm:
你好,请问这个还有源码吗?我刚开始接触这个,想要源码学习一下. ...
同一账号不能多地登录(限制同一账号同一时刻只能一个用户登录使用,向QQ一样) -
pangjinquan:
...
前台JS获取后台的Json数据, 动态创建table并填充数据--转自一位朋友 -
lvjun106:
这是增加删除列,,,,
JQuery自动为表格增加一列
文件头是位于文件开头的一段承担一定任务的数据,一般都在开头的部分。头文件作为一种包含功能函数、数据接口声明的载体文件,用于保存程序的声明(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文件时,不能用上述方法,因为文本文件不是二进制,则需要单独判断
为了解决在用户上传文件的时候在服务器端判断文件类型的问题,故用获取文件头的方式,直接读取文件的前几个字节,来判断上传文件是否符合格式。具体代码如下:
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也不对
xlsx被断为docx
pdf也不对
发表评论
-
诊断Java代码中常见的数据库性能热点问题
2016-09-01 11:49 611当我在帮助一些开发 ... -
同一账号不能多地登录(限制同一账号同一时刻只能一个用户登录使用,向QQ一样)
2014-12-30 11:36 9218解决四个问题: 1. 实现 ... -
java 将汉字转换为全拼及返回中文的首字母-带JAR包
2014-12-22 15:59 932import net.sourceforge.pinyin4 ... -
JSON中,java.lang.NoClassDefFoundError: net/sf/ezmorph/Morpher问题解决
2014-09-07 16:31 1221使用JSON,在SERVLET或者STRUTS的ACTION ... -
java 的 文件、文件夹 的建立、删除、复制以及移动等功能 操作
2014-08-23 09:00 753package util; import java. ... -
Java中sleep()与wait()的区别
2014-08-23 08:58 481一种解释: 功能差不 ... -
Java关键字final、static使用总结
2014-07-31 21:43 406一、final 根据程序上下文环境,Java关 ... -
Java 泛型 .
2014-07-02 23:17 742class Person{ private String n ... -
HashMap<String,HashMap<String,String>> 的多级映射 .
2014-07-02 23:13 1609package namespace;import java.u ... -
synchronized 和ThreadLocal 区别
2014-05-14 22:03 1166看了N个贴子,ThreadLocal讲得都不是很清楚,纠缠与 ... -
JAVA 常用加密方法
2014-05-10 18:45 10541.Base64 加密:org.apache.common ... -
Java二维数组的声明和初始化
2014-03-18 22:39 30381.二维数组可以看成以数组为元素的数组; 2.Java中二维数 ... -
POI操作Excel常用方法总结
2014-03-10 21:29 987一、POI简介 Apache POI是Apac ... -
JAVA垃圾回收机制,如何优化程序
2014-02-12 12:15 1035虽然程序员无法控制JVM的垃圾回收机制。但是可以通过编程的手段 ... -
HTTPClient PostMethod 中文乱码问题解决方案(2种)
2014-02-20 21:28 2375不过在实际使用中, 还是发现按照最基本的方式调用 Http ... -
List,set,Map 的用法和区别
2014-02-09 15:23 859Collection├List│├LinkedList│├Ar ... -
Object转Map Map->list array->list list->Map
2013-12-18 21:31 677Map map1= new HashMap(); map ... -
java List 排序 Collections.sort() 对 List 排序
2013-12-19 22:20 905//一个POJO例子class User { String ... -
SSH框架中使用log4j的方便之处
2013-12-14 13:39 743SSH框架中使用log4j的方便之处 1. 动态的改变记 ... -
无序hashset与hashmap让其有序
2013-12-14 13:39 3411今天迭代hashmap时,hashmap并不能按照put的 ...
相关推荐
本文将详细介绍一种在Android中使用Java根据文件头获取文件类型的实现方法。这个方法创建了一个名为`FileType`的类,其中包含一个`HashMap`用来存储不同文件类型与其对应的文件头信息。以下是一些常见文件类型的文件...
* 根据文件路径获取文件头信息 * * @param filePath 文件路径 * @return 文件头信息 */ public static String getFileType(String filePath) { String type = getFileHeader(filePath); System.out.println...
这是一个完整的myeclipse项目,主要实现的功能有: 1.用java获取wave类型的音频文件头信息; 2.根据传入参数截取指定时间段内的音频片段 改资源为本人原创,下载后导入myeclipse可以直接运行
4. **解析文件头**:根据已知的文件头格式,分析读取到的字节序列,以确定文件类型或提取用户信息。这一步可能涉及二进制数据的转换和字符串的比较。 ```java String headerString = new String(headerBytes, ...
本文主要介绍了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", ...
首先,对于不同类型的文件,获取时长的方法会有所不同。例如,音频文件(如mp3)和视频文件(如mp4)的处理方式就有所区别。对于音频文件,我们通常需要解析音频头部信息来获取时长;对于视频文件,可能需要解析容器...
本文将详细介绍如何在Java中获取文件的编码并判断文件是否带有BOM。 首先,让我们了解一下什么是BOM。BOM是UTF-8、UTF-16和UTF-32等编码格式中的一个可选标记,用于告知解析器文件的编码类型。例如,UTF-8的BOM是三...
2. Java 获取和判断文件头信息:如何使用 Java 语言来获取和判断文件头信息,包括如何使用 MultipartFile 对象来获取文件信息,以及如何判断文件的类型和大小等信息。 3. Ajax 文件上传:如何使用 Ajax 方式上传文件...
这个主题主要涉及两个核心工具类:`VerifyFileType.java` 和 `VerifyFileEncoder.java`,它们分别用于验证文件的类型和编码。接下来,我们将详细讨论这两个方面。 ### 文件类型验证 `VerifyFileType.java` 类很...
总的来说,Java中获取文件类型和扩展名的方式主要包括使用`File`类获取文件名和扩展名,以及通过探测MIME类型或读取文件头来判断文件类型。实际开发中,应根据具体需求选择合适的方法。注意,确保在处理用户提供的...
总的来说,获取视频时长需要对Java的文件I/O、网络请求以及多媒体处理有一定的了解。使用合适的库可以简化这个过程,提高效率。在实际应用中,确保处理的健壮性和效率是非常重要的,例如处理网络延迟、错误重试等。
根据数据包的类型,你可以进行相应的转换。 ```java if (packet instanceof IPacket) { IPacket ipPacket = (IPacket) packet; String sourceIP = ipPacket.src_ip.toString(); String destIP = ipPacket.dst_...
这篇博客“java根据IP获取城市代码”可能探讨了如何利用Java来解决这个问题。 首先,我们需要了解IP地址和城市代码的关系。IP地址是互联网上设备的唯一标识,由四段数字组成,每段之间用点分隔。城市代码通常指的是...
总的来说,获取文件类型的方法包括但不限于:检查文件扩展名、读取文件头信息、使用系统命令或特定库解析内容。根据实际需求和环境,选择合适的方法来实现文件类型的识别。在处理用户上传的文件时,一定要注意安全性...
4. 将文件内容添加到MultipartEntityBuilder,设置文件名和内容类型。 5. 设置“overwrite”参数,决定是否覆盖已存在的同名文件。 6. 将构建好的MultipartEntity设置到HttpPost对象。 7. 执行HttpPost请求并处理...
在读取AAC文件头时,我们需要确保缓冲区包含足够的数据来解析文件头,这可能需要多次调用`fill_buffer`以获取完整的信息。文件头通常位于文件的开始部分,包含了编码格式、帧长度、采样率、位深度等重要信息。 然后...
总结来说,"Java多个文件根据URL下载后打包zip导出"涉及的技术主要包括:网络请求、文件I/O、文件打包、HTML交互以及异步处理。理解这些知识点,可以帮助开发者构建一个功能完备的文件下载和打包系统。
在Java编程中,获取HTTP头信息是网络编程中常见的任务,尤其在开发Web应用程序或进行API交互时。HTTP头信息包含了许多关于请求或响应的重要元数据,如服务器信息、编码格式、Cookie等。本篇文章将深入讲解如何使用...