【发布时间】:2018-11-23 09:52:57
【问题描述】:
我正在从 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());
}
}
我尝试使用new FileInputStream(entry.getFile()) 直接保存entry,但这会返回null。
我需要创建一个saveTarStreamToS3() 还是可以从 TarArchiveInputStream 中创建一个 InputStream?
【问题讨论】:
标签: java amazon-s3 apache-commons-compress