现在的位置: 首页 > 综合 > 正文

struts2的常见错误

2018年05月11日 ⁄ 综合 ⁄ 共 6339字 ⁄ 字号 评论关闭

经过磕磕绊绊的探索、看帖子、看博客。终于把问题解决了。我现在把我出现的问题及解决办法和大家分享一下。不过不一定适合所有人。
错误:提交表单时出现404错误。控制台提示的信息是:2012-5-5 21:27:24 com.opensymphony.xwork2.util.logging.jdk.JdkLogger warn
警告: Could not find action or result
No result defined for action tr.LoginAction and result error
at com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:376)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:278)
at org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:256)
at com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:249)
at com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:176)...

struts.xml的配置:<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<package name="test" extends="struts-default">
<action name="login" class="tr.LoginAction">
<result name="success">/success.jsp</result>
<result name="ERROR">/error.jsp</result>
</action>
</package>
</struts>  
xx.java:public String execute() throws Exception {
if(getUsername().equals("tr") && getPassword().equals("tr")){
return Action.SUCCESS;
}else
return Action.ERROR;

}
解决办法:大家看到没,<result name="ERROR">/error.jsp</result>
这个"ERROR"是借口Action里的成员变量。如果把“ERROR”改成error就OK了!

 

 

错误:
在启动tomcat的时候,控制台输出:严重: Dispatcher initialization failed
java.lang.RuntimeException: java.lang.reflect.InvocationTargetException
at com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:295)
at com.opensymphony.xwork2.inject.ContainerImpl$ConstructorInjector.construct(ContainerImpl.java:431)
Caused by: java.lang.reflect.InvocationTargetException
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 com.opensymphony.xwork2.inject.ContainerImpl$MethodInjector.inject(ContainerImpl.java:293)
... 42 more
Caused by: java.lang.ExceptionInInitializerError
at com.opensymphony.xwork2.ognl.OgnlValueStackFactory.setContainer(OgnlValueStackFactory.java:85)
... 47 more
Caused by: java.lang.IllegalArgumentException: Javassist library is missing in classpath! Please add missed dependency!
at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:168)
... 48 more
Caused by: java.lang.ClassNotFoundException: javassist.ClassPool

aused by: java.lang.ExceptionInInitializerError
at com.opensymphony.xwork2.ognl.OgnlValueStackFactory.setContainer(OgnlValueStackFactory.java:85)
... 47 more
Caused by: java.lang.IllegalArgumentException: Javassist library is missing in classpath! Please add missed dependency!
at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:168)
... 48 more
Caused by: java.lang.ClassNotFoundException: javassist.ClassPool
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1645)
at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1491)
at java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:169)
at ognl.OgnlRuntime.<clinit>(OgnlRuntime.java:165)
... 48 more
2012-5-5 21:39:21 org.apache.catalina.core.StandardContext start
严重: Error filterStart
2012-5-5 21:39:21 org.apache.catalina.core.StandardContext start
严重: Context [/struts2] startup failed due to previous errors
2012-5-5 21:39:21 org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap
严重: The web application [/struts2] created a ThreadLocal with key of type [null] (value [com.opensymphony.xwork2.inject.ContainerImpl$10@56fc16]) and a value of type [java.lang.Object[]] (value [[Ljava.lang.Object;@c017e9]) but failed to remove it when the
web application was stopped. This is very likely to create a memory leak.
大家注意这条提示:Caused by: java.lang.ClassNotFoundException: javassist.ClassPool解决办法:在struts的app文件下的struts2-blank.war的压缩包里的WEB-INF/lib下有这个文件,将这个文件放在你的项目的lib下就行了

 

错误:[color=#FF0000]严重: Dispatcher initialization failed
Unable to load configuration. - action - file:/F:/apache-tomcat-6.0.29/webapps/error/WEB-INF/classes/struts.xml:5:42
 at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:58)
 at org.apache.struts2.dispatcher.Dispatcher.init_PreloadConfiguration(Dispatcher.java:374)
 at org.apache.struts2.dispatcher.Dispatcher.init(Dispatcher.java:418)
 at org.apache.struts2.dispatcher.ng.InitOperations.initDispatcher(InitOperations.java:69)
Caused by: Error building results for action test in namespace  - action - file:/F:/apache-tomcat-6.0.29/webapps/error/WEB-INF/classes/struts.xml:5:42
 at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.addAction(XmlConfigurationProvider.java:367)
 at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.addPackage(XmlConfigurationProvider.java:468)
 at com.opensymphony.xwork2.config.providers.XmlConfigurationProvider.loadPackages(XmlConfigurationProvider.java:264)
 at org.apache.struts2.config.StrutsXmlConfigurationProvider.loadPackages(StrutsXmlConfigurationProvider.java:111)
 at com.opensymphony.xwork2.config.impl.DefaultConfiguration.reloadContainer(DefaultConfiguration.java:193)
 at com.opensymphony.xwork2.config.ConfigurationManager.getConfiguration(ConfigurationManager.java:55)
 ... 31 more[/color]
[color=#00FF00]struts.xml配置:<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">
<struts>
<package name="test" >
<action name="test" class="tr.test.Test">
<result name="hello">/index.jsp</result>
</action>
</package>
</struts>   [/color]
解决办法:[package name="test" >
package没有扩展struts的默认包。改成
<package name="test" extends="struts-default">就OK了

 

另外附上我的web.xml配置:<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
 xmlns="http://java.sun.com/xml/ns/javaee"

 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee

 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  <filter>
   <filter-name>struts2</filter-name>
   <filter-class>
    org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
   </filter-class>
  </filter>
  <filter-mapping>
   <filter-name>struts2</filter-name>
   <url-pattern>/*</url-pattern>
  </filter-mapping></web-app>

抱歉!评论已关闭.