这就是问题:
我尝试使用Paths.get(string)
,Paths.get(URI)
,Paths.get(".").relativize(Path other)
等创建。总是得到相同的结果。
logger.info("referencePattern.getLocation().getYearFolder(year): "
+ referencePattern.getLocation().getYearFolder(year));
File rootFolder = new File(referencePattern.getLocation().getYearFolder(year));
logger.info("rootFolder.getAbsolutePath(): " + rootFolder.getAbsolutePath());
logger.info("rootFolder.getPath(): " + rootFolder.getPath());
logger.info("System.getProperty(\"user.dir\"): " + System.getProperty("user.dir"));
File[] files = rootFolder.listFiles(filter);
输出:
referencePattern.getLocation().getYearFolder(year): /dvl/app/srs/tomcat/data/dg/ep/docs_autres/commeenne/com/2018/
rootFolder.getAbsolutePath(): /dvl/app/srs/tomcat/temp//dvl/app/srs/tomcat/data/dg/ep/docs_autres/commeenne/com/2018
rootFolder.getPath(): /dvl/app/srs/tomcat/data/dg/ep/docs_autres/commeenne/com/2018
System.getProperty("user.dir"): /dvl/app/srs/tomcat/temp
来自comment:
getYearFolder(year)
将以下内容写入日志:
/dvl/app/srs/tomcat/data/ep/docs_autres/commeenne/com/2018/
getYearFolder(year).getBytes("UTF-8")
写道:
[36, 123, 115, 121, 115, 58, 117, 115, 101, 114, 46, 104, 111, 109, 101, 125, 47, 100, 97, 116, 97, 47, ...]
显示的字节代表字符串:
${sys:user.home}/data/
似乎logger.info(...)
正在进行替换,在记录的输出中用${sys:user.home}
替换/dvl/app/srs/tomcat
。
在Java代码中看到的实际值是${sys:user.home}/data/ep/docs_autres/commeenne/com/2018/
,它不以/
开头,因此被认为是相对路径,因此getAbsolutePath()
为当前目录(/dvl/app/srs/tomcat/temp
)的前缀,导致:
/dvl/app/srs/tomcat/temp/${sys:user.home}/data/ep/docs_autres/commeenne/com/2018/
然后记录器执行替换:
/dvl/app/srs/tomcat/temp//dvl/app/srs/tomcat/data/ep/docs_autres/commeenne/com/2018/
需要考虑的事项:
getYearFolder(year)
应该返回文件路径,为什么它会返回${sys:user.home}
?${sys:user.home}
应该被替换?肯定需要在调用getAbsolutePath()
之前。getAbsolutePath()
返回的路径已经被认为是绝对的话,为什么getYearFolder(year)
被调用?这些问题的答案应该提供如何解决问题的指导。