-
Notifications
You must be signed in to change notification settings - Fork 1.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
GuiceFilter breaks dispatching to jsp if jasper is being used to compile the jsp #372
Comments
From brianm%[email protected] on May 12, 2009 15:43:53 probably, if dispatching to a servlet, the request and response should be wrapped and I am seeing this under jetty 6.1.16 |
From dhanji on May 12, 2009 16:07:21 Yea this is a known issue--I've just not had any time to fix it up =( Note that this is a side effect of returning the wrong path in the requestDispatcher for JSP forwards. It affects Brownie points if you willing to submit a patch! |
From Leigh.Klotz on July 28, 2009 15:48:22 Is the problem somewhere near //noinspection OverlyComplexAnonymousInnerClass in |
From landon.wainwright on August 24, 2009 11:37:06 Yeah this is very annoying. I have been trying to solve it for a while now.Are there |
From tobiasapt on December 08, 2009 15:01:40 I've come up with a work around that works for Jasper. Jasper looks for a request public class JSPFixGuiceFilter extends GuiceFilter{ super.doFilter(request, response, filterChain); |
From burke.eric on December 21, 2009 13:56:29 This fails if MyServlet is managed by Guice. If this is just a normal unmanaged
In Tomcat I receive "HTTP Status 404 - /WEB-INF/protected_page.html" with description |
From burke.eric on December 21, 2009 14:42:00 I'm attaching a web app that demonstrates a problem dispatching to a static HTML file Binary attachments: guice_bug.zip, guice_bug.war |
From dhanji on December 30, 2009 16:06:43 Can this be considered fixed (I believe r1135 fixes it, but plz verify)? I will mark as fixed, plz reopen if there is still a problem. Status: Fixed |
From reynirhubner on June 24, 2010 08:46:32 I just tested this out. It does not work as intended. I have a filter that dispatches the request to a servlet. The dispatch almost works, except, when I check the value of request.getPathInfo(), I get "/servletName/c2/?param1=1" but should get "/servletName/c2/", as the request parameters should not be included... |
From dhanji on October 08, 2010 06:20:48 Can you submit a test case for this please? That would be the best way for us to verify. Thanks! Status: Accepted |
From [email protected] on April 03, 2011 19:38:11 I've encountered this too, on Jetty 7.2.2 + Guice 3.0 + Stripes 1.5.3. The original request matches a pattern ("/admin/*" in my case), and gets wrapped in a guice ServletDefinition$2 object. When the handling servlet does a forward, jetty wraps the guice request wrapper and then invokes setServletPath to point it to the new servlet. In my case, the forward is to "/WEB-INF/jsp/overview.jsp", and that string is what is passed to request.setServletPath(...). The jasper JspServlet then calls request.getServletPath() to find the jsp to render; this is handled by ServletDefinition$2 which calls super.getServletPath() to get the correct new path, but it then calls UriPatternType.extract("/WEB-INF/jsp/overview.jsp") which returns the path to the original servlet, ie "/admin"! Result is that the jsp cannot be found. |
From ori.schwartz on April 04, 2011 19:42:31 There's definitely a bug here. Here's the simplest test case (I'm using tomcat 5.5.33): * Use Guice ServletModule to configure two servlets, one of which just dispatches to the other: protected void configureServlets() * Dispatchee outputs text for verification, dispatcher redirects like this: protected void doGet( HttpServletRequest req, HttpServletResponse resp ) * Invoking /dispatcher yields a blank page with a 404 status that is incorrectly served up by Tomcat's default servlet. * When configuring via traditional web.xml instead of guice, everything works as expected. * I did some debugging and it looks like Tomcat's internal pattern matching inside its RequestDispatcher implementation isn't even aware of the servlet mapping that Guice configured. Attachment: gist |
From [email protected] on April 04, 2011 20:01:39 re#12: I think that's a different issue from the one discussed in the other comments on this bugreport. Tomcat definitely isn't aware of the mappings define via serve(x).with(y). The whole design is that when the original request comes in, the servlet container will not find a matching servlet (because there is no matching entry in web.xml), so will select the "default servlet" as the target. However it will run the Guice filter first, as that is mapped to "/*". And the guice filter then arranges for the request to be sent to the configured servlet instead of passing it to the (default) servlet that the web container chose. I would have thought that forwarding from one Guice-configured servlet to another would be supported (eg by creating a custom RequestDispatcher), but it isn't really necessary for most users. Forwarding from a guice-configured servlet to the container's JSP or static-resource servlet is critical, and this is the issue discussed in this bugreport. Note that comment#11 is about using a wildcard-suffix (eg "/admin/"). The existing code works fine with wildcard-prefixes (eg ".do"), because UriPatternType.extract returns null in this case, causing ServletDefinition$2.getServletPath() to return the (correct) path from the parent class. |
From ori.schwartz on April 05, 2011 09:00:59 Thanks Simon (#13), that explains it. You are right, this is not the same as the JSP issue discussed in this report. Should I open a separate issue for the behavior I reported? It seems like an important fix to me. Lots of apps use ServletContext#getRequestDispatcher to forward requests internally. |
From sberlin on April 05, 2011 09:46:00 Yes, please open a separate issue. If someone is able to also attach a patch with a testcase & fix that: That will help very much in fixing this. |
From ori.schwartz on April 05, 2011 09:57:15 I've opened up issue 621 for the above comment #12 (forward method in ServeltContext#getRequestDispatcher). |
From valotas on June 03, 2011 13:59:38 re#11: serveRegex("/admin/.*").with(YourAdminServlet.class) should work. At least that solved the same problem I had with a servlet mapped to a wildcard-suffix path. |
From valotas on June 05, 2011 12:54:35 Attached a possible solution with its test. I'm not sure if it is the best possible one as I do not know if a custom HttpServletRequest that tries to mimic servlet container behavior of computing stuff like the request paths is needed by the guice-servlet module internals. Attachment: gist |
From sberlin on June 05, 2011 12:59:16 Would you be able to attach a patch instead of the new file as a whole? Thanks! (Patches are much easier to review.) |
From valotas on June 05, 2011 13:09:30 If you can help me on how to do that! Never had to do it before! |
From sberlin on June 05, 2011 13:16:50 If you're using Eclipse there should be a Team -> Create Patch option on the file or project (right-click to find it). If you're using SVN directly, use 'svn diff > patch.txt'. You have to have the code checked out from SVN (either directly, through Eclipse, or through whatever IDE you're using). It's harder if you just are modifying the src jars (but possible.. you need a diff tool & the original & modified files). See: https://code.google.com/p/google-guice/source/checkout for how to get the source from SVN. |
From valotas on June 05, 2011 13:41:48 Ok, attached you can find a patch file! Attachment: gist |
From valotas on September 11, 2011 10:38:40 It's been a while! Has this been fixed? Is there any problem (or any other problem) regarding the patch provided? I would be glad to investigate more if that is the case! |
From sberlin on October 16, 2011 09:33:09 Is it possible to write a test-case also? I prefer not to apply patches without tests attached, especially when I don't know the code as well. The test will make sure the problem doesn't regress, and also highlight what was wrong in the first place. Owner: sberlin |
From valotas on October 16, 2011 13:08:06 Isn't the ServletDefinitionPathsTest enough? This is what I added: It should fail if you try to run it without the ServletDefinition changes |
From arman.vartan on April 08, 2014 07:50:27 After 3.5 years this patch has neither found its way into any minor v3 release nor any work as been done to fix this issue in the v4 betas. As this is not a minor bug and has been addressed in several other tickets, please revise the status of this ticket. |
From valotas on April 08, 2014 07:56:06 It looks like the servlet module is not a high prio one :( |
From valotas on April 08, 2014 08:08:09 Well, last comment was mine, explaining where to find the test requested. The fact that you requested a test case means that you did not review the patch that you requested me :) Anyway, I can not confirm now that the patch will work against the latest code at the trunk (as mentioned by the development team, there are quite some changes to the guice internals). |
From sberlin on April 08, 2014 08:09:44 I remember looking at it, but missed the fact that a test was added (given that the test was just a single line) -- I was expecting a whole method. I'll try to find some time to apply it & confirm it doesn't expose other problems. |
From valotas on April 08, 2014 08:17:09 No problem. Happy to have helped :) |
From valotas on April 08, 2014 08:22:11 Have though in mind what I've said to my previous response: "I'm not sure if it is the best possible one as I do not know if a custom HttpServletRequest that tries to mimic servlet container behavior of computing stuff like the request paths is needed by the guice-servlet module internals" I really do not know of a better way, but in order to make sure that the guice-servlet does not break the servlet specifications is to write tests against the servlet specifications :/ |
From arman.vartan on April 08, 2014 08:22:40 Wow, that was fast. Thanks guys :) |
From sberlin on April 10, 2014 06:31:35 I have a few questions about the patch: |
From valotas on April 10, 2014 07:50:13 I think that you are right. I can not remember my intention on the code I wrote 3y ago :) I'll try to have a look at it the following days |
From sberlin on April 10, 2014 13:28:56 Can you confirm if putting works for you too? Based on the javadoc for getPathInfo, it seems incorrect to have pathInfo be the same as the servletPath. |
From sberlin on April 10, 2014 16:28:14 Fixed by r=c35ebc2ce88f & r=f1abba38c7f5. Status: Fixed |
From brianm%[email protected] on May 12, 2009 18:42:37
The Jasper JSP compiler uses request.getServletPath() to name the JSP file.
When dispatched to a JSP under the filter the servlet path is either empty
or /, which leads to an error when generating a class name for the jsp file
before it can be compiled.
This is happening in 2.0- r943
Original issue: http://code.google.com/p/google-guice/issues/detail?id=372
The text was updated successfully, but these errors were encountered: