0

我正在从 FTP 获取文件。我得到的文件是文本文件或 tar.gz

对于文本文件,我只是将它们发送到 S3。如果我遇到一个 tar.gz 我想解压它并用相同的方法保存每个文件。

public void handleFile() {

    try (InputStream fileStream = ftpFileService.getInputStream(file)) {
        if (file.getName().lastIndexOf(".TGZ") > -1) {
            TarArchiveInputStream tar = new TarArchiveInputStream(new GzipCompressorInputStream(fileStream));
            TarArchiveEntry entry = null;
            while ((entry = tar.getNextTarEntry()) != null) {
                LOGGER.info("fileName to save {}", entry.getName());
                saveStreamToS3(entry.getName(), new InputStream(tar));
            }
            tar.close();
        } else {
            LOGGER.info("fileName to save {}", fileName.getName());
            saveStreamToS3(fileName.getName(), fileStream);
        }
    } catch (IOException e) {
        LOGGER.error(e.getMessage());
    }
}

我尝试保存entry直接使用new FileInputStream(entry.getFile()),但这返回null。

我需要制作一个saveTarStreamToS3()还是可以从 TarArchiveInputStream 制作一个 InputStream?

4

1 回答 1

1

FileInputStream 只读取真实文件。它不会从存档中读取数据。

有两种可能的解决方案

  • 使用InputStream哪些 FileInputStream 和 TarArchiveInputStream 隐含
  • 将文件复制到磁盘,使用 FileInputStream 读取,然后删除。

界面上的目的InputStream是让您不需要知道数据来自哪里,这是解决这个问题的自然方法。

我可以用 TarArchiveInputStream 制作 InputStream

TarArchiveInputStream 实现了 InputStream 所以没有什么可做的。

于 2018-11-23T09:58:47.860 回答