[ 
https://issues.apache.org/struts/browse/WW-1977?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#action_41832
 ] 

Matt Raible commented on WW-1977:
---------------------------------

Some more information:

This happens on Tomcat 5.0.25, Tomcat 5.0.28 and Tomcat 6.0.13. It also happens 
on Jetty 6.1.5. It does *not* happen when using the maven-jetty-plugin (version 
jetty-6.1.5rc0).

On Jetty 6.1.5 standalone, it appears to have information for both the 404 and 
a 500 - as represented by the error message that's presented:

HTTP ERROR: 404

There is no Action mapped for namespace / and action name usersda2.

RequestURI=/light/usersda2.html
Caused by:

There is no Action mapped for namespace / and action name usersda2. - [unknown 
location]
        at 
com.opensymphony.xwork2.DefaultActionProxy.prepare(DefaultActionProxy.java:186)
        at 
org.apache.struts2.impl.StrutsActionProxyFactory.createActionProxy(StrutsActionProxyFactory.java:41)
        at 
org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:494)
        at 
org.apache.struts2.dispatcher.FilterDispatcher.doFilter(FilterDispatcher.java:419)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
com.opensymphony.module.sitemesh.filter.PageFilter.parsePage(PageFilter.java:118)
        at 
com.opensymphony.module.sitemesh.filter.PageFilter.doFilter(PageFilter.java:52)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
org.apache.struts2.dispatcher.ActionContextCleanUp.doFilter(ActionContextCleanUp.java:99)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
org.displaytag.filter.ResponseOverrideFilter.doFilter(ResponseOverrideFilter.java:125)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
        at 
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:75)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at org.appfuse.web.MessageFilter.doFilter(MessageFilter.java:32)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:96)
        at 
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:75)
        at 
org.mortbay.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1084)
        at 
org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:360)
        at 
org.mortbay.jetty.security.SecurityHandler.handle(SecurityHandler.java:216)
        at 
org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:181)
        at 
org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:712)
        at org.mortbay.jetty.webapp.WebAppContext.handle(WebAppContext.java:405)
        at 
org.mortbay.jetty.handler.ContextHandlerCollection.handle(ContextHandlerCollection.java:211)
        at 
org.mortbay.jetty.handler.HandlerCollection.handle(HandlerCollection.java:114)
        at 
org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:139)
        at org.mortbay.jetty.Server.handle(Server.java:313)
        at 
org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:506)
        at 
org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:830)
        at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:514)
        at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:211)
        at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:381)
        at 
org.mortbay.io.nio.SelectChannelEndPoint.run(SelectChannelEndPoint.java:396)
        at 
org.mortbay.thread.BoundedThreadPool$PoolThread.run(BoundedThreadPool.java:442)

Powered by Jetty://

> Struts throws stack trace instead of 404 when an action doesn't exist
> ---------------------------------------------------------------------
>
>                 Key: WW-1977
>                 URL: https://issues.apache.org/struts/browse/WW-1977
>             Project: Struts 2
>          Issue Type: Bug
>          Components: Actions
>    Affects Versions: 2.0.6
>            Reporter: Matt Raible
>             Fix For: 2.1.0
>
>
> If I request an action that doesn't exist, Struts displays a "Struts Problem 
> Report" page with a stack trace like the following:
> here is no Action mapped for namespace / and action name blabla. - [unknown 
> location]
>       at 
> com.opensymphony.xwork2.DefaultActionProxy.prepare(DefaultActionProxy.java:186)
>       at 
> org.apache.struts2.impl.StrutsActionProxyFactory.createActionProxy(StrutsActio
> In my struts.xml:
>     <constant name="struts.devMode" value="false"/>
>     <constant name="struts.i18n.encoding" value="UTF-8"/>
>     <constant name="struts.action.extension" value="html"/>
>     <constant name="struts.objectFactory" value="spring"/>
>     <constant name="struts.custom.i18n.resources" 
> value="ApplicationResources,errors"/>
>     <constant name="struts.multipart.maxSize" value="2097152"/>
>     <constant name="struts.ui.theme" value="css_xhtml"/>
>     <constant name="struts.codebehind.pathPrefix" value="/WEB-INF/pages/"/>
> Strangely enough, in another application I was able to change struts.devMode 
> from true to false to fix this problem. However, since it's already false in 
> this application, I'm not sure how to fix it.
> To reproduce, go to: http://demo.appfuse.org/appfuse-struts/blabla.html and 
> login with user/user.

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

Reply via email to