string path = @"E:\test\新建 Microsoft Office PowerPoint 演示文稿.zip"; //全路径格式
FileStream fs = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read); //以流的方式读取文件
byte[] b = new byte[13]; //指定读取字节的长度
fs.Seek(31, SeekOrigin.Begin); //指定位置读取.如office 2007 的docx,直接改zip如果读前2个字节会是相同的PK值
fs.Read(b, 0, b.Length); //读取字节内容保存到b对象字节中
string fix = Encoding.Default.GetString(b); //进行字节编码
Console.WriteLine(fix); //输出 "content_types"
if (fix.IndexOf("Content_Types") > -1) //判断文件头是否包含该文字,如果有则是通过 docx文件直接改装过来的
{
Console.WriteLine("是改装文件");
}
else
{
FileStream fss = new FileStream(path, FileMode.Open, FileAccess.Read, FileShare.Read); //在次读取字节流.
byte[] sb = new byte[2]; //这次读取的就是直接0-1的位置长度了.
fss.Read(sb, 0, sb.Length);
string fixs = Encoding.Default.GetString(sb); //字节编码 输出 pk
Console.WriteLine(fixs);
if (fixs.ToLower().Equals("pk")) //判断是否是pk值,有就是zip/jar格式.否则其他格式
{
Console.WriteLine("Ok 是jar/zip");
}
else
{
Console.WriteLine("NO 是rar文件后其他格式");
}
}
上面的方法进行了两次二进制文件的读取,在效率上可能会比较低.但是通过自己的想法,如果要过滤文件是通过"*.docx"等文件格式之间通过变更成"*.zip".的格式,上面的方法比较笨重,还有什么好的方法可以以后再找找资料,也希望各位提供更好的方法....交流