如何在multipart / form-data请求中获取文件的实际文件大小

时间:2015-12-09 16:57:31

标签: file-upload http-headers multipartform-data

正如标题所说,我需要获取作为multipart/form-data请求发布的文件的真实文件大小。

我的基础是JSF世界,但我认为这个问题与技术无关(仅取决于HTTP)。

Content-Length 标头中指定的值不足,因为它包含边界和其他表单参数。

示例请求(仅限正文):

-----------------------------355432893771247592819421210
Content-Disposition: form-data; name="composeform"

composeform
-----------------------------355432893771247592819421210

Content-Disposition: form-data; name="javax.faces.ViewState"

-9107117821100047188:3613431652649065231
-----------------------------355432893771247592819421210
Content-Disposition: form-data; name="file"; filename="3byte.txt"
Content-Type: text/plain

abc

-----------------------------355432893771247592819421210--

请求正文的最后一部分包含文件,在本例中是一个名为“3byte.txt”的文件,其中包含字符“abc”。

正如您所看到的,文件大小不包含在请求中,因此我看到获取值的唯一方法是根据 Content-Length 标头和大小来计算它。边界和其他形式参数。

其他要求:

  • 解决方案不应该读取/解析整个请求以获取文件大小(这显然很容易)
  • 请求中可能有更多表单参数,包含文件的部分之前或之后(与我的示例相反)

未解决问题的类似问题:

1 个答案:

答案 0 :(得分:3)

  1. 您不能指望为multipart消息设置Content-Length标头(某些多部分请求类型甚至禁止内容长度标头)。只需要 Content-Length标题 Transfer-Encoding标题。

  2. 多部分邮件的一部分中不得有Content-Length标头。

  3. 但是,您的发件人可能在处置标头中设置其他参数。您可以利用它来设置文件大小,如下所示:

    Content-Disposition: form-data; name="file"; filename="3byte.txt"; size=123
    

    但这纯粹是可选的,参数的名称是任意的,并且不需要发送者来包含此参数。这意味着,HTTP服务器引擎永远不能依赖它。