Am testing with a client who send me a HTTP request with no content length header but has a content.
How do I extract this content without the help of contentlength header?
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
I’ve kept the original answer for completeness, but I’ve just been looking in the HTTP RFC (2616) section 4.3:
So if you haven’t got a content length, you must have a Transfer-Encoding (and if you haven’t, you should respond with a 400 status to indicate a bad request or 411 (“length required”)). At that point, you do what the Transfer-Encoding tells you 🙂
Now if you’re dealing with a servlet API (or a similar HTTP API) it may well handle all this for you – at which point you may be able to use the techique below to read from the stream until it yields no more data, as the API will take care of it (i.e. it won’t just be a raw socket stream).
If you could give us more information about your context, that would help.
Original answer
If there’s no content length, that means the content continues until the end of the data (when the socket closes).
Keep reading from the input stream (e.g. writing it to a ByteArrayOutputStream to store it, or possibly a file) until
InputStream.readreturns -1. For example:EDIT: As has been pointed out in comments, the client could be using a chunked encoding. Normally the HTTP API you’re using should deal with this for you, but if you’re dealing with a raw socket you’d have to handle it yourself.
The point about this being a request (and therefore the client not being able to close the connection) is an interesting one – I thought the client could just shut down the sending part, but I don’t see how that maps to anything in TCP at the moment. My low-level networking knowledge isn’t what it might be.
If this answer turns out to be “definitely useless” I’ll delete it…