导入的jar包:
import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPFile;
问题: ftpFile.getTimestamp().getTimeInMillis()获取到的时间和源文件的时间相差8小时
原因: 查阅资料后发现是ftp设置的是utc时间,和系统时间有8小时时差
解决: 查询到文件时间后将时差偏移量进行补全
解决后代码片段:
FTPFile[] files = ftpClient.listFiles();
//遍历文件列表
for (FTPFile ftpFile : files) {
//判断是否根据正则表达式获取文件列表
if (StringUtils.isNotBlank(taskRule.getRegex())) {
if (!ftpFile.getName().matches(taskRule.getRegex())) {
continue;
}
}
log.info("{}文件大小为{}",ftpFile.getName(),ftpFile.getSize());
//判断文件大小是否为0
if (ftpFile.getSize() == 0) {
log.info("{}文件大小为0",ftpFile.getName());
return null;
}
//utc时间加上时间差
Long addTime = ftpFile.getTimestamp().getTimeInMillis() +
ftpFile.getTimestamp().getTimeZone().getOffset(0);
Date date = new Date(addTime);
long pastHour = DateUtils.pastHour(date);
log.info("name:{},fileTimeStamp:{},pastHour:{}", ftpFile.getName(), date, pastHour);
if (pastHour < taskRule.getHourScope()) {
fileNames.add(ftpFile.getName());
}
}