首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >具有多个文件的Multipart HTTP请求应该是什么样子?

具有多个文件的Multipart HTTP请求应该是什么样子?
EN

Stack Overflow用户
提问于 2018-03-09 01:50:14
回答 2查看 0关注 0票数 0

我正在开发一个iPhone应用程序,它可以对多个图像文件进行多部分HTTP请求。

它看起来像在服务器端发生的事情是,其中一个图像得到了正确的解析,但其他两个文件却没有。

我想请问怎样才可以发布包含多个图像文件的示例HTTP多部分请求呢?

EN

回答 2

Stack Overflow用户

发布于 2018-03-09 10:04:29

我已将每个非打印的ascii字符转换为如下,你可以参考下:

代码语言:javascript
复制
POST /cgi-bin/qtest HTTP/1.1
Host: aram
User-Agent: Mozilla/5.0 Gecko/2009042316 Firefox/3.0.10
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-Alive: 300
Connection: keep-alive
Referer: http://aram/~martind/banner.htm
Content-Type: multipart/form-data; boundary=----------287032381131322
Content-Length: 514

------------287032381131322
Content-Disposition: form-data; name="datafile1"; filename="r.gif"
Content-Type: image/gif

GIF87a.............,...........D..;
------------287032381131322
Content-Disposition: form-data; name="datafile2"; filename="g.gif"
Content-Type: image/gif

GIF87a.............,...........D..;
------------287032381131322
Content-Disposition: form-data; name="datafile3"; filename="b.gif"
Content-Type: image/gif

GIF87a.............,...........D..;
------------287032381131322--
票数 0
EN

Stack Overflow用户

发布于 2018-03-09 10:53:41

请使用nc -l浏览器或cURL等用户代理。

将表单保存到.html文件中:

代码语言:javascript
复制
<form action="http://localhost:8000" method="post" enctype="multipart/form-data">
  <p><input type="text" name="text" value="text default">
  <p><input type="file" name="file1">
  <p><input type="file" name="file2">
  <p><button type="submit">Submit</button>
</form>

创建要上传的文件:

代码语言:javascript
复制
echo 'Content of a.txt.' > a.txt
echo '<!DOCTYPE html><title>Content of a.html.</title>' > a.html

执行:

代码语言:javascript
复制
nc -l localhost 8000

在浏览器中打开HTML,选择文件并点击提交并检查终端。

使用Firefox发送:

代码语言:javascript
复制
POST / HTTP/1.1
Host: localhost:8000
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:29.0) Gecko/20100101 Firefox/29.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
Cookie: __atuvc=34%7C7; permanent=0; _gitlab_session=226ad8a0be43681acf38c2fab9497240; __profilin=p%3Dt; request_method=GET
Connection: keep-alive
Content-Type: multipart/form-data; boundary=---------------------------9051914041544843365972754266
Content-Length: 554

-----------------------------9051914041544843365972754266
Content-Disposition: form-data; name="text"

text default
-----------------------------9051914041544843365972754266
Content-Disposition: form-data; name="file1"; filename="a.txt"
Content-Type: text/plain

Content of a.txt.

-----------------------------9051914041544843365972754266
Content-Disposition: form-data; name="file2"; filename="a.html"
Content-Type: text/html

<!DOCTYPE html><title>Content of a.html.</title>

-----------------------------9051914041544843365972754266--

或者,cURL应该发送与浏览器表单相同的POST请求:

代码语言:javascript
复制
nc -l localhost 8000
curl -F "text=default" -F "file1=@a.html" -F "file1=@a.txt" localhost:8000

你可以用以下方法进行多项测试:

代码语言:javascript
复制
while true; do printf '' | nc -l localhost 8000; done
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/-100003592

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档