Is there a way to get raw http request stream from Java servlet handler?

后端 未结 3 885
南笙
南笙 2020-12-18 11:27

I am trying to put some logging to capture the raw http request coming to my application. My Java code is inside a SpringMVC controller. I have access to the \"HttpServletRe

相关标签:
3条回答
  • 2020-12-18 12:08

    No.

    The servlet provides no such API, and it would be hard to implement because (basically) you cannot read the same data twice from a Socket. It is not difficult to get header information, but raw headers are impossible to capture within a servlet container. To get the bodies you need to capture them yourself as your application reads/writes the relevant streams.

    Your alternatives are:

    1. Write your own server-side implementation of the HTTP protocol. (Probably not right for your application.)

    2. You may be able to get the header information you need with filters, though they don't show the raw requests.

    3. Some servlet containers have request header logging; e.g. with Tomcat there's a beast called the RequestDumperValve that you can configure in your "server.xml" file.

    4. Implement a proxy server that sits between the client and your "real" server.

    5. Packet sniffing.

    Which is best depends on what you are really trying to achieve.

    FOLLOWUP:

    If the "badness" is in the headers, the RequestDumperValve approach is probably the best for debugging. Go to the "$CATALINA_HOME/conf/server.xml" file, search for "RequestDumperValve" and uncomment the element. Then restart Tomcat. You can also do the equivalent in your webapp's "context.xml" file. The dumped requests and responses end up in "logs/catalina.out" by default. Note that this will give a LOT of output, so you don't want to do this in production ... except as a last resort.

    If the badness is in the content of a POST or PUT request, you'll need to modify your application to save a copy the content as it reads it from the input stream. I'm not aware of any shortcuts for this.

    Also, if you want to leave logging on for long periods, you'll probably need to solve the problem yourself by calling the HttpServletRequest API and logging headers, etc. The RequestDumperValve generates too much output, and dumps ALL requests not just the bad ones.

    0 讨论(0)
  • 2020-12-18 12:21

    No, servlets provide no api to get at the raw request - you might need a sniffer like wireshark for that.

    You can get at the parsed request headers and uri though:

    • getHeaderNames()
    • getRequestURI()

    etc.

    0 讨论(0)
  • 2020-12-18 12:29

    I managed to read my raw request in my webapplication deployed on Tomcat 5.5

    All I had to do is to read HttpServletRequest through my servlet/Spring controller using request.getInputStream() only.
    It must be the first API approach to the request. before any filter or other command start to mass with the request that cause its completely reading by the webserver.

    What's the problem with that approach?

    0 讨论(0)
提交回复
热议问题