zoukankan      html  css  js  c++  java
  • 使用apache.tika判断文件类型

    一. 判断文件类型一般可采用两种方式

      1. 后缀名判断

         简单易操作,但无法准确判断类型

      2. 文件头信息判断

        通常可以判断文件类型,但有些文件类型无法判断(如word和excel头信息的前几个字节是一样的,无法判断)

      3. 使用apache.tika可轻松解决以上两种方式存在的问题

    二. 使用方式

      1. maven依赖

    <dependency>
        <groupId>org.apache.tika</groupId>
        <artifactId>tika-core</artifactId>
        <version>1.22</version>
    </dependency>

      2. 具体实现

     1 public static String getMimeType(InputStream inputStream){
     2     AutoDetectParser parser = new AutoDetectParser();
     3     parser.setParsers(new HashMap<MediaType, Parser>());
     4 
     5     Metadata metadata = new Metadata();
     6 
     7     try {
     8         parser.parse(inputStream, new DefaultHandler(), metadata, new ParseContext());
     9         inputStream.close();
    10     } catch (TikaException | SAXException | IOException e) {
    11         e.printStackTrace();
    12     }
    13 
    14     return metadata.get(HttpHeaders.CONTENT_TYPE);
    15 }

      3. 常见文件类型

    MimeType文件类型
    application/msword word(.doc)
    application/vnd.ms-powerpoint powerpoint(.ppt)
    application/vnd.ms-excel excel(.xls)
    application/vnd.openxmlformats-officedocument.wordprocessingml.document word(.docx)
    application/vnd.openxmlformats-officedocument.presentationml.presentation powerpoint(.pptx)
    application/vnd.openxmlformats-officedocument.spreadsheetml.sheet excel(.xlsx)
    application/x-rar-compressed rar
    application/zip zip
    application/pdf pdf
    video/* 视频文件
    image/* 图片文件
    text/plain 纯文本
    text/css css文件
    text/html html文件
    text/x-java-source java源代码
    text/x-csrc c源代码
    text/x-c++src c++源代码
  • 相关阅读:
    Asp.net core中间件实现原理及用法解说
    C#中,async关键字到底起什么作用?
    C# 中的Async 和 Await 的用法详解
    .NET委托,事件和Lambda表达式
    docker push到私有仓库 docker push 镜像到harbor
    shell tput的用法
    Shell中获取脚本的绝对路径$( cd "$( dirname "$0" )" && pwd)
    shell脚本中 "set -e" 的作用
    从旧goadddy账号转移域名到新的goaddy账号中
    git制作patch的步骤
  • 原文地址:https://www.cnblogs.com/Mr-kevin/p/12014611.html
Copyright © 2011-2022 走看看