关于RTF格式解析和doc格式解析的问题

发布于 2022-09-01 21:34:54 字数 101 浏览 17 评论 0

最近在做文件解析的工作,目前用的开源的POI解决doc和docx来解析,但是遇到rtf格式的会报错,请问java通过什么来判断后缀名为.doc的文件到底是word文件还是rtf格式文件呢?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

勿忘初心 2022-09-08 21:34:54

检查文件头,即文件的头几个字节。常见的 MIME Type 解析也是这个原理。因为阁下的需求非常简单,所以这里我也就不推荐用于 MIME 类型判断的第三方封装了。
RTF 定义类型的头几个字节经搜索查询得出是(十六进制):7B 5C 72 74 66
所以只需要读取文件的头五个字节,然后转换成 16 进制形式表现的字符串,再与“7b5c727466”比较即可判断是否为 RTF 类型。

FileInputStream fis = new FileInputStream(file);
byte[] bytes = new byte[5];
fis.read(bytes, 0, bytes.length);
fis.close();
StringBuffer header=new StringBuffer();
for (byte b : bytes) {
    String hex=Integer.toHexString(b);
    if(hex.length()<2){// 两位以下补〇
        header.append('0');
    }
    header.append(hex);
}
boolean isRTF="7b5c727466".contentEquals(header);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文