You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@struts.apache.org by "Adam Ruggles (JIRA)" <ji...@apache.org> on 2008/11/16 08:15:38 UTC

[jira] Created: (WW-2873) action named "logout" fails.

action named "logout" fails.
----------------------------

                 Key: WW-2873
                 URL: https://issues.apache.org/struts/browse/WW-2873
             Project: Struts 2
          Issue Type: Bug
          Components: Core Actions
    Affects Versions: 2.1.2
         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
            Reporter: Adam Ruggles


I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.

see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.

Bellow is my configuration:

public class LogoutAction implements ServletRequestAware, Serializable {
        private static final long serialVersionUID = -5615396306298191276L;
        private HttpServletRequest request;

        public void setServletRequest(final HttpServletRequest request) {
                this.request = request;
        }

        public String execute() throws Exception {
                request.getSession().invalidate();
                return Action.SUCCESS;
        }
}

struts.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">

<struts>
        <!-- Constant Settings -->
        <constant name="struts.enable.DynamicMethodInvocation" value="false" />
        <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
        <constant name="struts.url.includeParams" value="none" />
        <constant name="struts.custom.i18n.resources" value="global-messages" />
        <constant name="struts.ui.theme" value="atalatal" />
        <constant name="struts.objectFactory" value="guice" />
        <constant name="guice.module" value="kiff.util.LoaderModule" />

        <!-- Development Settings "Change these when going to production" -->
        <constant name="struts.devMode" value="true" />
        <constant name="struts.i18n.reload" value="true" />
        <constant name="struts.configuration.xml.reload" value="true" />

        <package name="boardDefault" extends="struts-default">
                <interceptors>
                        <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />

                        <interceptor-stack name="defaultSecuredStack">
                                <interceptor-ref name="timer" />
                                <interceptor-ref name="exception" />
                                <interceptor-ref name="alias" />
                                <interceptor-ref name="servletConfig" />
                                <interceptor-ref name="login" />
                                <interceptor-ref name="params" />
                                <interceptor-ref name="prepare" />
                                <interceptor-ref name="i18n" />
                                <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
                                <interceptor-ref name="profiling" />
                                <interceptor-ref name="scopedModelDriven" />
                                <interceptor-ref name="modelDriven" />
                                <interceptor-ref name="fileUpload" />
                                <interceptor-ref name="checkbox" />
                                <interceptor-ref name="staticParams" />
                                <interceptor-ref name="actionMappingParams" />
                                <interceptor-ref name="params" />
                                <interceptor-ref name="conversionError" />
                                <interceptor-ref name="validation">
                                       
input,back,cancel,browse
                                </interceptor-ref>
                                <interceptor-ref name="workflow">
                                        input,back,cancel,browse
                                </interceptor-ref>
                        </interceptor-stack>

                        <interceptor-stack name="defaultInsecureStack">
                                <interceptor-ref name="timer" />
                                <interceptor-ref name="exception" />
                                <interceptor-ref name="alias" />
                                <interceptor-ref name="servletConfig" />
                                <interceptor-ref name="params" />
                                <interceptor-ref name="prepare" />
                                <interceptor-ref name="i18n" />
                                <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
                                <interceptor-ref name="profiling" />
                                <interceptor-ref name="scopedModelDriven" />
                                <interceptor-ref name="modelDriven" />
                                <interceptor-ref name="fileUpload" />
                                <interceptor-ref name="checkbox" />
                                <interceptor-ref name="staticParams" />
                                <interceptor-ref name="actionMappingParams" />
                                <interceptor-ref name="params">
                                        dojo\..*
                                </interceptor-ref>
                                <interceptor-ref name="conversionError" />
                                <interceptor-ref name="validation">
                                        input,back,cancel,browse
                                </interceptor-ref>
                                <interceptor-ref name="workflow">
                                        input,back,cancel,browse
                                </interceptor-ref>

                        </interceptor-stack>
                </interceptors>

                <default-interceptor-ref name="defaultInsecureStack" />

                <default-action-ref name="index" />

                <global-results>
                        <result name="error">/WEB-INF/pages/error/default.jsp
                        </result>
                        <result name="login">/WEB-INF/pages/login.jsp
                        </result>
                </global-results>

                <global-exception-mappings>
                        <exception-mapping result="java.lang.Exception"
                                exception="error" />
                </global-exception-mappings>

                <action name="index">
                        <result name="input">/WEB-INF/pages/index.jsp
                        </result>
                        <result name="success">/WEB-INF/pages/index.jsp
                        </result>
                </action>
                <action name="login">
                        <interceptor-ref name="defaultSecuredStack" />
                        <result name="success" type="redirectAction">
                                index
                                /
                        </result>
                </action>
                <action name="out" class="kiff.action.LogoutAction">
                        <result name="success" type="redirectAction">
                                index
                                /
                        </result>
                </action>
                <action name="logout" class="kiff.action.LogoutAction">
                        <result name="success" type="redirectAction">
                                index
                                /
                        </result>
                </action>
        </package>

        <!-- Mapping Files  -->
        <!-- <include file="struts-mappings.xml"/>  -->

</struts>

Here is my stack trace.

 No result defined for action kiff.action.LogoutAction and result success

    com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
    com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
    org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
    com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
    com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
    com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
    com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
    com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
    org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
    org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
    org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
    org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
    org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
    org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
    org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
    org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
    org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
    org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
    java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


[jira] Updated: (WW-2873) action named "logout" fails.

Posted by "James Holmes (JIRA)" <ji...@apache.org>.
     [ https://issues.apache.org/struts/browse/WW-2873?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

James Holmes updated WW-2873:
-----------------------------

    Fix Version/s: 2.1.3

> action named "logout" fails.
> ----------------------------
>
>                 Key: WW-2873
>                 URL: https://issues.apache.org/struts/browse/WW-2873
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core Actions
>    Affects Versions: 2.1.2
>         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
>            Reporter: Adam Ruggles
>             Fix For: 2.1.3
>
>
> I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.
> see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.
> Bellow is my configuration:
> public class LogoutAction implements ServletRequestAware, Serializable {
>         private static final long serialVersionUID = -5615396306298191276L;
>         private HttpServletRequest request;
>         public void setServletRequest(final HttpServletRequest request) {
>                 this.request = request;
>         }
>         public String execute() throws Exception {
>                 request.getSession().invalidate();
>                 return Action.SUCCESS;
>         }
> }
> struts.xml
> <?xml version="1.0" encoding="UTF-8" ?>
> <!DOCTYPE struts PUBLIC
>     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
>     "http://struts.apache.org/dtds/struts-2.0.dtd">
> <struts>
>         <!-- Constant Settings -->
>         <constant name="struts.enable.DynamicMethodInvocation" value="false" />
>         <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
>         <constant name="struts.url.includeParams" value="none" />
>         <constant name="struts.custom.i18n.resources" value="global-messages" />
>         <constant name="struts.ui.theme" value="atalatal" />
>         <constant name="struts.objectFactory" value="guice" />
>         <constant name="guice.module" value="kiff.util.LoaderModule" />
>         <!-- Development Settings "Change these when going to production" -->
>         <constant name="struts.devMode" value="true" />
>         <constant name="struts.i18n.reload" value="true" />
>         <constant name="struts.configuration.xml.reload" value="true" />
>         <package name="boardDefault" extends="struts-default">
>                 <interceptors>
>                         <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />
>                         <interceptor-stack name="defaultSecuredStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="login" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                        
> input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                         <interceptor-stack name="defaultInsecureStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params">
>                                         dojo\..*
>                                 </interceptor-ref>
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                 </interceptors>
>                 <default-interceptor-ref name="defaultInsecureStack" />
>                 <default-action-ref name="index" />
>                 <global-results>
>                         <result name="error">/WEB-INF/pages/error/default.jsp
>                         </result>
>                         <result name="login">/WEB-INF/pages/login.jsp
>                         </result>
>                 </global-results>
>                 <global-exception-mappings>
>                         <exception-mapping result="java.lang.Exception"
>                                 exception="error" />
>                 </global-exception-mappings>
>                 <action name="index">
>                         <result name="input">/WEB-INF/pages/index.jsp
>                         </result>
>                         <result name="success">/WEB-INF/pages/index.jsp
>                         </result>
>                 </action>
>                 <action name="login">
>                         <interceptor-ref name="defaultSecuredStack" />
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="out" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="logout" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>         </package>
>         <!-- Mapping Files  -->
>         <!-- <include file="struts-mappings.xml"/>  -->
> </struts>
> Here is my stack trace.
>  No result defined for action kiff.action.LogoutAction and result success
>     com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
>     com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
>     org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
>     org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
>     org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
>     org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>     org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>     org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>     org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>     org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>     org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>     org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>     org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>     org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
>     org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>     org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>     java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


[jira] Commented: (WW-2873) action named "logout" fails.

Posted by "Adam Ruggles (JIRA)" <ji...@apache.org>.
    [ https://issues.apache.org/struts/browse/WW-2873?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=45187#action_45187 ] 

Adam Ruggles commented on WW-2873:
----------------------------------

I've uploaded a war with the issue here.
http://kiff.googlecode.com/files/kiff-0.0.1-SNAPSHOT.war

The source code for the project is:
http://code.google.com/p/kiff/source/checkout

After you deploy the war follow these instructions to see the issue.

1) Browse to http://localhost:8080/kiff/install/index.action
2) Type in any site name/description and admin information. The administrator stuff is for logging in.
3) Click save.
4) Click login
5) Use the information type on the install page to login.
6) Click Logout

> action named "logout" fails.
> ----------------------------
>
>                 Key: WW-2873
>                 URL: https://issues.apache.org/struts/browse/WW-2873
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core Actions
>    Affects Versions: 2.1.2
>         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
>            Reporter: Adam Ruggles
>             Fix For: 2.1.3
>
>
> I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.
> see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.
> Bellow is my configuration:
> public class LogoutAction implements ServletRequestAware, Serializable {
>         private static final long serialVersionUID = -5615396306298191276L;
>         private HttpServletRequest request;
>         public void setServletRequest(final HttpServletRequest request) {
>                 this.request = request;
>         }
>         public String execute() throws Exception {
>                 request.getSession().invalidate();
>                 return Action.SUCCESS;
>         }
> }
> struts.xml
> <?xml version="1.0" encoding="UTF-8" ?>
> <!DOCTYPE struts PUBLIC
>     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
>     "http://struts.apache.org/dtds/struts-2.0.dtd">
> <struts>
>         <!-- Constant Settings -->
>         <constant name="struts.enable.DynamicMethodInvocation" value="false" />
>         <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
>         <constant name="struts.url.includeParams" value="none" />
>         <constant name="struts.custom.i18n.resources" value="global-messages" />
>         <constant name="struts.ui.theme" value="atalatal" />
>         <constant name="struts.objectFactory" value="guice" />
>         <constant name="guice.module" value="kiff.util.LoaderModule" />
>         <!-- Development Settings "Change these when going to production" -->
>         <constant name="struts.devMode" value="true" />
>         <constant name="struts.i18n.reload" value="true" />
>         <constant name="struts.configuration.xml.reload" value="true" />
>         <package name="boardDefault" extends="struts-default">
>                 <interceptors>
>                         <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />
>                         <interceptor-stack name="defaultSecuredStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="login" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                        
> input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                         <interceptor-stack name="defaultInsecureStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params">
>                                         dojo\..*
>                                 </interceptor-ref>
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                 </interceptors>
>                 <default-interceptor-ref name="defaultInsecureStack" />
>                 <default-action-ref name="index" />
>                 <global-results>
>                         <result name="error">/WEB-INF/pages/error/default.jsp
>                         </result>
>                         <result name="login">/WEB-INF/pages/login.jsp
>                         </result>
>                 </global-results>
>                 <global-exception-mappings>
>                         <exception-mapping result="java.lang.Exception"
>                                 exception="error" />
>                 </global-exception-mappings>
>                 <action name="index">
>                         <result name="input">/WEB-INF/pages/index.jsp
>                         </result>
>                         <result name="success">/WEB-INF/pages/index.jsp
>                         </result>
>                 </action>
>                 <action name="login">
>                         <interceptor-ref name="defaultSecuredStack" />
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="out" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="logout" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>         </package>
>         <!-- Mapping Files  -->
>         <!-- <include file="struts-mappings.xml"/>  -->
> </struts>
> Here is my stack trace.
>  No result defined for action kiff.action.LogoutAction and result success
>     com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
>     com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
>     org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
>     org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
>     org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
>     org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>     org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>     org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>     org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>     org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>     org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>     org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>     org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>     org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
>     org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>     org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>     java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


[jira] Resolved: (WW-2873) action named "logout" fails.

Posted by "Musachy Barroso (JIRA)" <ji...@apache.org>.
     [ https://issues.apache.org/struts/browse/WW-2873?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Musachy Barroso resolved WW-2873.
---------------------------------

    Resolution: Not A Problem

The problem is that you have codebehind in your app, and Codebehind is defining a "logout" action, without results, which overwrites the one from xml.

> action named "logout" fails.
> ----------------------------
>
>                 Key: WW-2873
>                 URL: https://issues.apache.org/struts/browse/WW-2873
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core Actions
>    Affects Versions: 2.1.2
>         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
>            Reporter: Adam Ruggles
>             Fix For: 2.1.3
>
>
> I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.
> see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.
> Bellow is my configuration:
> public class LogoutAction implements ServletRequestAware, Serializable {
>         private static final long serialVersionUID = -5615396306298191276L;
>         private HttpServletRequest request;
>         public void setServletRequest(final HttpServletRequest request) {
>                 this.request = request;
>         }
>         public String execute() throws Exception {
>                 request.getSession().invalidate();
>                 return Action.SUCCESS;
>         }
> }
> struts.xml
> <?xml version="1.0" encoding="UTF-8" ?>
> <!DOCTYPE struts PUBLIC
>     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
>     "http://struts.apache.org/dtds/struts-2.0.dtd">
> <struts>
>         <!-- Constant Settings -->
>         <constant name="struts.enable.DynamicMethodInvocation" value="false" />
>         <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
>         <constant name="struts.url.includeParams" value="none" />
>         <constant name="struts.custom.i18n.resources" value="global-messages" />
>         <constant name="struts.ui.theme" value="atalatal" />
>         <constant name="struts.objectFactory" value="guice" />
>         <constant name="guice.module" value="kiff.util.LoaderModule" />
>         <!-- Development Settings "Change these when going to production" -->
>         <constant name="struts.devMode" value="true" />
>         <constant name="struts.i18n.reload" value="true" />
>         <constant name="struts.configuration.xml.reload" value="true" />
>         <package name="boardDefault" extends="struts-default">
>                 <interceptors>
>                         <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />
>                         <interceptor-stack name="defaultSecuredStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="login" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                        
> input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                         <interceptor-stack name="defaultInsecureStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params">
>                                         dojo\..*
>                                 </interceptor-ref>
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                 </interceptors>
>                 <default-interceptor-ref name="defaultInsecureStack" />
>                 <default-action-ref name="index" />
>                 <global-results>
>                         <result name="error">/WEB-INF/pages/error/default.jsp
>                         </result>
>                         <result name="login">/WEB-INF/pages/login.jsp
>                         </result>
>                 </global-results>
>                 <global-exception-mappings>
>                         <exception-mapping result="java.lang.Exception"
>                                 exception="error" />
>                 </global-exception-mappings>
>                 <action name="index">
>                         <result name="input">/WEB-INF/pages/index.jsp
>                         </result>
>                         <result name="success">/WEB-INF/pages/index.jsp
>                         </result>
>                 </action>
>                 <action name="login">
>                         <interceptor-ref name="defaultSecuredStack" />
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="out" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="logout" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>         </package>
>         <!-- Mapping Files  -->
>         <!-- <include file="struts-mappings.xml"/>  -->
> </struts>
> Here is my stack trace.
>  No result defined for action kiff.action.LogoutAction and result success
>     com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
>     com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
>     org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
>     org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
>     org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
>     org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>     org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>     org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>     org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>     org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>     org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>     org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>     org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>     org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
>     org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>     org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>     java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


[jira] Resolved: (WW-2873) action named "logout" fails.

Posted by "Musachy Barroso (JIRA)" <ji...@apache.org>.
     [ https://issues.apache.org/struts/browse/WW-2873?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Musachy Barroso resolved WW-2873.
---------------------------------

    Resolution: Cannot Reproduce

I added the following, to stuts-tags-ui.xml in showcase:

<action name="logout" class="org.apache.struts2.showcase.UITagExample">
            <result name="success">example.jsp</result>
 </action>

and going to :http://localhost:8080/struts2-showcase/tags/ui/logout.action , renders the right page. Everything looks good in your config, so I am not sure what the problem is, but I don't think it is in S2. If you can submit an small app that replicates the problem, I will look into it.



> action named "logout" fails.
> ----------------------------
>
>                 Key: WW-2873
>                 URL: https://issues.apache.org/struts/browse/WW-2873
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core Actions
>    Affects Versions: 2.1.2
>         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
>            Reporter: Adam Ruggles
>             Fix For: 2.1.3
>
>
> I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.
> see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.
> Bellow is my configuration:
> public class LogoutAction implements ServletRequestAware, Serializable {
>         private static final long serialVersionUID = -5615396306298191276L;
>         private HttpServletRequest request;
>         public void setServletRequest(final HttpServletRequest request) {
>                 this.request = request;
>         }
>         public String execute() throws Exception {
>                 request.getSession().invalidate();
>                 return Action.SUCCESS;
>         }
> }
> struts.xml
> <?xml version="1.0" encoding="UTF-8" ?>
> <!DOCTYPE struts PUBLIC
>     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
>     "http://struts.apache.org/dtds/struts-2.0.dtd">
> <struts>
>         <!-- Constant Settings -->
>         <constant name="struts.enable.DynamicMethodInvocation" value="false" />
>         <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
>         <constant name="struts.url.includeParams" value="none" />
>         <constant name="struts.custom.i18n.resources" value="global-messages" />
>         <constant name="struts.ui.theme" value="atalatal" />
>         <constant name="struts.objectFactory" value="guice" />
>         <constant name="guice.module" value="kiff.util.LoaderModule" />
>         <!-- Development Settings "Change these when going to production" -->
>         <constant name="struts.devMode" value="true" />
>         <constant name="struts.i18n.reload" value="true" />
>         <constant name="struts.configuration.xml.reload" value="true" />
>         <package name="boardDefault" extends="struts-default">
>                 <interceptors>
>                         <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />
>                         <interceptor-stack name="defaultSecuredStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="login" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                        
> input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                         <interceptor-stack name="defaultInsecureStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params">
>                                         dojo\..*
>                                 </interceptor-ref>
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                 </interceptors>
>                 <default-interceptor-ref name="defaultInsecureStack" />
>                 <default-action-ref name="index" />
>                 <global-results>
>                         <result name="error">/WEB-INF/pages/error/default.jsp
>                         </result>
>                         <result name="login">/WEB-INF/pages/login.jsp
>                         </result>
>                 </global-results>
>                 <global-exception-mappings>
>                         <exception-mapping result="java.lang.Exception"
>                                 exception="error" />
>                 </global-exception-mappings>
>                 <action name="index">
>                         <result name="input">/WEB-INF/pages/index.jsp
>                         </result>
>                         <result name="success">/WEB-INF/pages/index.jsp
>                         </result>
>                 </action>
>                 <action name="login">
>                         <interceptor-ref name="defaultSecuredStack" />
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="out" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="logout" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>         </package>
>         <!-- Mapping Files  -->
>         <!-- <include file="struts-mappings.xml"/>  -->
> </struts>
> Here is my stack trace.
>  No result defined for action kiff.action.LogoutAction and result success
>     com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
>     com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
>     org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
>     org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
>     org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
>     org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>     org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>     org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>     org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>     org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>     org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>     org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>     org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>     org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
>     org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>     org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>     java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.


[jira] Reopened: (WW-2873) action named "logout" fails.

Posted by "Musachy Barroso (JIRA)" <ji...@apache.org>.
     [ https://issues.apache.org/struts/browse/WW-2873?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Musachy Barroso reopened WW-2873:
---------------------------------


Reopening to test provided test case. Thanks!

> action named "logout" fails.
> ----------------------------
>
>                 Key: WW-2873
>                 URL: https://issues.apache.org/struts/browse/WW-2873
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Core Actions
>    Affects Versions: 2.1.2
>         Environment: Windows Vista x64, JDK 1.6.0_07, tomcat 6.0.18
>            Reporter: Adam Ruggles
>             Fix For: 2.1.3
>
>
> I'm having an issue with naming one of my actions logout. I have a action named logout and another one called out.  They both have the exact same class and results.  However when I try to browse to logout.action I get a stack trace and when I browse to out.action everything works as expected.  I tested this issue using spring and guice both with the same issue.
> see http://www.nabble.com/Something-special-about-action-named-%22logout%22-td20513297.html for more information.
> Bellow is my configuration:
> public class LogoutAction implements ServletRequestAware, Serializable {
>         private static final long serialVersionUID = -5615396306298191276L;
>         private HttpServletRequest request;
>         public void setServletRequest(final HttpServletRequest request) {
>                 this.request = request;
>         }
>         public String execute() throws Exception {
>                 request.getSession().invalidate();
>                 return Action.SUCCESS;
>         }
> }
> struts.xml
> <?xml version="1.0" encoding="UTF-8" ?>
> <!DOCTYPE struts PUBLIC
>     "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
>     "http://struts.apache.org/dtds/struts-2.0.dtd">
> <struts>
>         <!-- Constant Settings -->
>         <constant name="struts.enable.DynamicMethodInvocation" value="false" />
>         <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/" />
>         <constant name="struts.url.includeParams" value="none" />
>         <constant name="struts.custom.i18n.resources" value="global-messages" />
>         <constant name="struts.ui.theme" value="atalatal" />
>         <constant name="struts.objectFactory" value="guice" />
>         <constant name="guice.module" value="kiff.util.LoaderModule" />
>         <!-- Development Settings "Change these when going to production" -->
>         <constant name="struts.devMode" value="true" />
>         <constant name="struts.i18n.reload" value="true" />
>         <constant name="struts.configuration.xml.reload" value="true" />
>         <package name="boardDefault" extends="struts-default">
>                 <interceptors>
>                         <interceptor name="login" class="kiff.interceptor.LoginInterceptor" />
>                         <interceptor-stack name="defaultSecuredStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="login" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                        
> input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                         <interceptor-stack name="defaultInsecureStack">
>                                 <interceptor-ref name="timer" />
>                                 <interceptor-ref name="exception" />
>                                 <interceptor-ref name="alias" />
>                                 <interceptor-ref name="servletConfig" />
>                                 <interceptor-ref name="params" />
>                                 <interceptor-ref name="prepare" />
>                                 <interceptor-ref name="i18n" />
>                                 <interceptor-ref name="debugging" /> <!-- Remove debug and profiling before prod. -->
>                                 <interceptor-ref name="profiling" />
>                                 <interceptor-ref name="scopedModelDriven" />
>                                 <interceptor-ref name="modelDriven" />
>                                 <interceptor-ref name="fileUpload" />
>                                 <interceptor-ref name="checkbox" />
>                                 <interceptor-ref name="staticParams" />
>                                 <interceptor-ref name="actionMappingParams" />
>                                 <interceptor-ref name="params">
>                                         dojo\..*
>                                 </interceptor-ref>
>                                 <interceptor-ref name="conversionError" />
>                                 <interceptor-ref name="validation">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                                 <interceptor-ref name="workflow">
>                                         input,back,cancel,browse
>                                 </interceptor-ref>
>                         </interceptor-stack>
>                 </interceptors>
>                 <default-interceptor-ref name="defaultInsecureStack" />
>                 <default-action-ref name="index" />
>                 <global-results>
>                         <result name="error">/WEB-INF/pages/error/default.jsp
>                         </result>
>                         <result name="login">/WEB-INF/pages/login.jsp
>                         </result>
>                 </global-results>
>                 <global-exception-mappings>
>                         <exception-mapping result="java.lang.Exception"
>                                 exception="error" />
>                 </global-exception-mappings>
>                 <action name="index">
>                         <result name="input">/WEB-INF/pages/index.jsp
>                         </result>
>                         <result name="success">/WEB-INF/pages/index.jsp
>                         </result>
>                 </action>
>                 <action name="login">
>                         <interceptor-ref name="defaultSecuredStack" />
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="out" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>                 <action name="logout" class="kiff.action.LogoutAction">
>                         <result name="success" type="redirectAction">
>                                 index
>                                 /
>                         </result>
>                 </action>
>         </package>
>         <!-- Mapping Files  -->
>         <!-- <include file="struts-mappings.xml"/>  -->
> </struts>
> Here is my stack trace.
>  No result defined for action kiff.action.LogoutAction and result success
>     com.opensymphony.xwork2.DefaultActionInvocation.executeResult(DefaultActionInvocation.java:357)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:259)
>     com.opensymphony.xwork2.interceptor.DefaultWorkflowInterceptor.doIntercept(DefaultWorkflowInterceptor.java:141)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.validator.ValidationInterceptor.doIntercept(ValidationInterceptor.java:248)
>     org.apache.struts2.interceptor.validation.AnnotationValidationInterceptor.doIntercept(AnnotationValidationInterceptor.java:49)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ConversionErrorInterceptor.intercept(ConversionErrorInterceptor.java:124)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ParametersInterceptor.doIntercept(ParametersInterceptor.java:170)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.StaticParametersInterceptor.intercept(StaticParametersInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.CheckboxInterceptor.intercept(CheckboxInterceptor.java:84)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.FileUploadInterceptor.intercept(FileUploadInterceptor.java:208)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ModelDrivenInterceptor.intercept(ModelDrivenInterceptor.java:88)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ScopedModelDrivenInterceptor.intercept(ScopedModelDrivenInterceptor.java:127)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ProfilingActivationInterceptor.intercept(ProfilingActivationInterceptor.java:104)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.debugging.DebuggingInterceptor.intercept(DebuggingInterceptor.java:267)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ChainingInterceptor.intercept(ChainingInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.I18nInterceptor.intercept(I18nInterceptor.java:143)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.PrepareInterceptor.doIntercept(PrepareInterceptor.java:137)
>     com.opensymphony.xwork2.interceptor.MethodFilterInterceptor.intercept(MethodFilterInterceptor.java:86)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.interceptor.ServletConfigInterceptor.intercept(ServletConfigInterceptor.java:164)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.AliasInterceptor.intercept(AliasInterceptor.java:130)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     com.opensymphony.xwork2.interceptor.ExceptionMappingInterceptor.intercept(ExceptionMappingInterceptor.java:176)
>     com.google.inject.struts2.GuiceObjectFactory$ProvidedInterceptor.intercept(GuiceObjectFactory.java:224)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:230)
>     com.opensymphony.xwork2.DefaultActionInvocation$1.doProfiling(DefaultActionInvocation.java:229)
>     com.opensymphony.xwork2.util.profiling.UtilTimerStack.profile(UtilTimerStack.java:456)
>     com.opensymphony.xwork2.DefaultActionInvocation.invoke(DefaultActionInvocation.java:227)
>     org.apache.struts2.impl.StrutsActionProxy.execute(StrutsActionProxy.java:52)
>     org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:477)
>     org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:467)
>     org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
>     org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>     org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>     org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
>     org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>     org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>     org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>     org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:286)
>     org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:845)
>     org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:583)
>     org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>     java.lang.Thread.run(Thread.java:619) 

-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.