现象
Tomcat日志
java.io.IOException: 文件名、目录名或卷标语法不正确。 at java.io.WinNTFileSystem.canonicalize0(Native Method) at java.io.WinNTFileSystem.canonicalize(WinNTFileSystem.java:428) at java.io.File.getCanonicalPath(File.java:618) at org.apache.catalina.startup.ExpandWar.expand(ExpandWar.java:137) at org.apache.catalina.startup.ContextConfig.fixDocBase(ContextConfig.java:605) at org.apache.catalina.startup.ContextConfig.beforeStart(ContextConfig.java:738) at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:301) at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:94) at org.apache.catalina.util.LifecycleBase.setStateInternal(LifecycleBase.java:395) at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:149) at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:754) at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:730) at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:734) at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:985) at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1857) at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) at java.util.concurrent.FutureTask.run(FutureTask.java:266) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at java.lang.Thread.run(Thread.java:748)
原因
自己手动在自己的机器上面用解压后,然后,将解压后的文件夹复制到windows中,windows报文件名太长,无法完成复制之类的错误。然后,就寻这windows提供的无法复制文件目录看了一看,没有发现谁文件名长,然后,看了一下自己工程源码里面的目录,发现多了两个雷缓存文件。再次跑到windows上面,查看隐藏文件,发现了那两个出问题的雷缓存文件(我去,还有人往服务器上面复制这些,也是够了)。
解决
在工程里面删除这个两个*雷文件,重新编译打包war,重新部署就没有什么问题了。
总结
win上面报错不是很明显的情况下面,应该考虑各种方式尝试解决问题,或许在行动的过程中,它会告诉你那里出问题了。