首页 > 解决方案 > 如何获取 Office 文档的子类型 MIME,而不是在 Tika 中获取 OOXML

问题描述

我正在使用 Tika 来验证文件类型,并确保没有人试图以真实文件的名义发送恶意或虚假文件。为此,我正在使用 Apache Tika。但是,即使我将 InputStream 包装到 TikaInputStream 中,或者使用 OOXMLParser 或 OfficeParser,它仍然返回 application/x-tika-ooxml 而不是 application/vnd.openxmlformats-officedocument.wordprocessingml.document。我如何访问或让它返回子类型?

    public static boolean isValidFileMimeType(TikaInputStream stream, String[] validMimes) {
    Tika tika = new Tika();
    try {
        Metadata meta = new Metadata();
        tika.detect(stream, meta);
        String mimetype = meta.get("Content-Type");
        logger.debug("MIME type from TIKA is : [" + mimetype +"]");
        logger.debug(meta.toString());
        //return isValidFileMimeType(mimetype, validMimes);
        return true;
    } catch (Exception e) {
        logger.error("Error validating InputStream: ", e);
        return false;
    }

public static boolean isValidFileMimeType(MultipartFile file, String[] mimeTypes) {
    TikaInputStream in = null;
    boolean isValidFile = false;
     try {
         in = TikaInputStream.get(file.getInputStream());
        isValidFile = DataValidator.isValidFileMimeType(in, mimeTypes);
    } catch (IOException e) {
        logger.error("Error while validating file mime type: ", e);
    } finally {
        if (in != null) {
            try {
                in.close();
            } catch (IOException e2) {
                logger.error("Error while closing InputStream: ", e2);
            }
        }
    }
        return isValidFile;
}

标签: javamimeapache-tika

解决方案


只需导入/使用 Tika 解析器


推荐阅读