我试图将文件从一个位置移动到另一个位置,当我通过命令提示符运行.jar时,它工作正常,但当robot调度器(使用不同的服务帐户)触发jar时,出现以下错误
java.io.IOException: The handle is invalid
at java.io.WinNTFileSystem.canonicalize0(Native Method)
at java.io.WinNTFileSystem.canonicalize(Unknown Source)
at java.io.File.getCanonicalPath(Unknown Source)
at org.apache.commons.io.FileUtils.copyFile(FileUtils.java:1076)
at org.apache.commons.io.FileUtils.copyFile(FileUtils.java:1040)
下面是我用于filemove的方法
public static Boolean fileMove(File source, String destination) {
LOG.info(destination + File.separator + source.getName());
LOG.info(source.getAbsolutePath());
File dest = new File(destination + File.separator + source.getName());
try {
FileUtils.copyFile(source, dest);
return FileUtils.contentEquals(source, dest) && Files.deleteIfExists(source.toPath());
} catch (IOException e) {
LOG.warn("IO Error Occurred during file Operations", e);
return false;
}
}
``` `LOG.info(destination + File.separator + source.getName())` 日志记录在路径//uk001/eucl/email\u broker\u archive\mime-message--7431406574003289236.eml下
(destination=//uk001/eucl/email\u broker\u archive,file.separator='\',source.getname()=mime-message--7431406574003289236.eml) `LOG.info(source.getAbsolutePath())` 正在低于路径记录
\uk001\eucl\source\0002\mime-message--7431406574003289236.eml
服务帐户(cmd和robot scheduler)都有r/w权限,并且应用程序正在windows服务器上运行。
1条答案
按热度按时间cx6n0qe31#
似乎是文件分隔符与操作系统的文件分隔符不匹配的问题。
//uk001/eucl/email\u broker\u archive\mime-message--7431406574003289236.eml
请更换并检查\是否存在问题。另外,在一直复制文件之前,请执行if检查文件是否存在。