java.lang.NoSuchMethodError: org.apache.commons.io.FileUtils.moveFile(Ljava/io/File;Ljava/io/File;)V
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain.doBackUp(AssetRincsSeiyakuRenkeiMain.java:399)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain.execute(AssetRincsSeiyakuRenkeiMain.java:242)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c.$$execute$$invokeSuperMethod$$(AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c.java)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c$$MethodInvocation$$execute0.proceed(MethodInvocationClassGenerator.java)
at org.seasar.framework.aop.interceptors.ThrowsInterceptor.invoke(ThrowsInterceptor.java:79)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c$$MethodInvocation$$execute0.proceed(MethodInvocationClassGenerator.java)
at org.seasar.framework.aop.interceptors.TraceInterceptor.invoke(TraceInterceptor.java:73)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c$$MethodInvocation$$execute0.proceed(MethodInvocationClassGenerator.java)
at project.asst.batch.main.AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c.execute(AssetRincsSeiyakuRenkeiMain$$EnhancedByS2AOP$$3458213c.java)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at project.asst.core.batch.BatchActionHandler.handleBatchMain(BatchActionHandler.java:107)
at project.asst.core.batch.BatchExecuter.execute(BatchExecuter.java:44)
at project.asst.core.batch.BatchExecuter.main(BatchExecuter.java:63)
但是我从方法FileUtils.moveFile(src, dest);
进入看到是commons-io-2.0.1.jar
和commons-io-2.1.jar
明明都有这个方法,为什么找不到.!!!
eclipse中使用快捷键Ctrl+Shift+T
输入这个类的全路径org.apache.commons.io.FileUtils
,如下上图
红框 : 上图是当前项目中相同’全class路径’有这么5个jar包提供,下图可以看出Maven库的jar包优先级比本地/lib/jar包优先级高
蓝框 : 当前项目中相同’全class路径’有这么5个jar
绿框 : 想要使用到的jar包
Maven仓库里的commons-io-1.3.2.jar
里确实没有FileUtils.moveFile()这个方法
通过调整顺序,把Maven仓库的顺序移动至最底下,调整之前,请先记录好你当前的Order顺序
调整顺序后,引起另外一个错误,如下
2024-08-22 12:01:09,080 [main] FATAL project.asst.core.batch.BatchExceptionHandler - プログラム上、予期しないエラーが発生しました。
java.lang.ExceptionInInitializerError
at org.seasar.framework.container.factory.SingletonS2ContainerFactory.init(SingletonS2ContainerFactory.java:152)
at project.asst.core.batch.BatchManager.init(BatchManager.java:23)
at project.asst.core.batch.BatchExecuter.main(BatchExecuter.java:59)
Caused by: org.seasar.framework.exception.ParserConfigurationRuntimeException: [ESSR0053]パーサの設定に問題があります。理由はjavax.xml.parsers.ParserConfigurationException: Feature 'http://apache.org/xml/features/xinclude' is not recognized.
at org.seasar.framework.util.SAXParserFactoryUtil.newSAXParser(SAXParserFactoryUtil.java:75)
at org.seasar.framework.container.factory.XmlS2ContainerBuilder.createSaxHandlerParser(XmlS2ContainerBuilder.java:192)
at org.seasar.framework.container.factory.XmlS2ContainerBuilder.parse(XmlS2ContainerBuilder.java:167)
at org.seasar.framework.container.factory.XmlS2ContainerBuilder.build(XmlS2ContainerBuilder.java:148)
at org.seasar.framework.container.factory.S2ContainerFactory.configure(S2ContainerFactory.java:233)
at org.seasar.framework.container.factory.S2ContainerFactory.configure(S2ContainerFactory.java:211)
at org.seasar.framework.container.factory.S2ContainerFactory.<clinit>(S2ContainerFactory.java:116)
... 3 more
Caused by: javax.xml.parsers.ParserConfigurationException: Feature 'http://apache.org/xml/features/xinclude' is not recognized.
at org.apache.xerces.jaxp.SAXParserFactoryImpl.newSAXParser(Unknown Source)
at org.seasar.framework.util.SAXParserFactoryUtil.newSAXParser(SAXParserFactoryUtil.java:73)
... 9 more
99
2024-08-22 12:01:09,081 [main] FATAL project.asst.core.batch.BatchExceptionHandler - プログラム上、予期しないエラーが発生しました。
引起原因:s2-framework-2.4.46.jar
就是要调用xercesImpl-2.6.2.jar
这个jar包,但是它就是报这个错,
藕只好把外面的xercesImpl-2.7.1.jar
改名字为xercesImpl-2.6.2.jar
放进Maven仓库的\.m2\repository\xerces\xercesImpl\2.6.2
位置,鸠占鹊巢,然后clean项目,跑起来就好了.