研究jforum的项目,eclipse集成开发,自己写了一个demo,运行是报错,提示:
16:53:58,006 ERROR [ExceptionWriter ] java.lang.ClassNotFoundException: net.jforum.test.TestAction
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
首先检查了,TestAction编译的结果,编译正确,class文件已经生成。
再次确认是否缓存没有清理,或者使用的是老的war包,在源代码中加入print语句,正确显示,重启tomcat无数次。可以判断使用的是新编译生成的class。
debug进去发现在Web-inf下的class文件夹下确实没有生成TestAction.class文件。
原因很奇怪,周边无人知晓,上网请教高手。
private Command retrieveCommand(String moduleClass) throws Exception
{
return (Command)Class.forName(moduleClass).newInstance();
}
有这个class文件
12:05:51,687 ERROR [ExceptionWriter ] java.lang.ClassNotFoundException: net.jforum.test.TestAction
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1680)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1526)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at net.jforum.JForum.retrieveCommand(JForum.java:321)
at net.jforum.JForum.processCommand(JForum.java:233)
at net.jforum.JForum.service(JForum.java:217)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at net.jforum.util.legacy.clickstream.ClickstreamFilter.doFilter(ClickstreamFilter.java:59)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:291)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:602)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
at java.lang.Thread.run(Thread.java:662)URL is: /jforum/test/show/arg1/arg2.page?null
你检查一下modulesMapping.properties里边的配置
如:“myTest=net.jforum.view.forum.MyTestAction ”
这里后边有空格也是不行的
只能是“myTest=net.jforum.view.forum.MyTestAction”这里很容易就会出错 为了方便
可以在JForum类中添加一行代码
moduleClass=moduleClass.trim();(大约在169行,String moduleClass = module != null ? ModulesRepository.getModuleClass(module) : null;后面)