Struts and logging HTTP POST request body

Posted by Ivan Vrtaric on Stack Overflow See other posts from Stack Overflow or by Ivan Vrtaric
Published on 2010-03-15T16:31:00Z Indexed on 2010/03/15 17:39 UTC
Read the original article Hit count: 470

Filed under:
|
|
|
|

I'm trying to log the raw body of HTTP POST requests in our application based on Struts, running on Tomcat 6. I've found one previous post on SO that was somewhat helpful, but the accepted solution doesn't work properly in my case. The problem is, I want to log the POST body only in certain cases, and let Struts parse the parameters from the body after logging. Currently, in the Filter I wrote I can read and log the body from the HttpServletRequestWrapper object, but after that Struts can't find any parameters to parse, so the DispatchAction call (which depends on one of the parameters from the request) fails.

I did some digging through Struts and Tomcat source code, and found that it doesn't matter if I store the POST body into a byte array, and expose a Stream and a Reader based on that array; when the parameters need to get parsed, Tomcat's Request object accesses its internal InputStream, which has already been read by that time.

Does anyone have an idea how to implement this kind of logging correctly?

© Stack Overflow or respective owner

Related posts about java

Related posts about struts