我对标题感到抱歉,但目前我没有足够的创造力来获得更好的标题。
我正在尝试将文件上传到xup.in(在C#中提供一些API)。但不知何故,请求不是有效的。 xup.in可以读取它,也可以读取Wireshark。后请求有效,但多部分表单数据不是。
请求由以下功能发送:
http://pastebin.com/AvwzxCLA(抱歉,我无法使用代码标记)
这是我创建请求的方式:http://pastebin.com/btrg9xiZ
谁能告诉我我做错了什么?
答案 0 :(得分:0)
在黑暗中刺入 - 边界字符串需要具有前导--
,并且消息的最后一行必须具有以下形式:--boundarystring--
,否则消息无效。维基百科上的MIME Entry包含了消息应该是什么样子的一个很好的例子。将请求转储到文件并确保它是有效的多部分消息是一个良好的开端。
修改强>
您应该使用System.Net.WebClient框架,而不是您使用的方法。它封装了所有这些功能。
通过改变你的mime体构造,我成功地从脚本上传了。注意,我从参数中删除了Content-Type
,因为它不需要,而且我确保boundString已正确形成,即作为boundaryString
传入的字符串是请求中使用的字符串标题,没有前导--
我让函数执行双重任务 - 只有在Stream为null
时才会计算大小。
public static long sendMultiPartReq(Stream req, string boundaryString, object[] files, object[] parameters)
{
String CRLF = "\r\n";
byte[] b;
long contentLength = 0;
foreach (string[] file in files)
{
b = Encoding.UTF8.GetBytes(
CRLF + "--" + boundaryString + CRLF +
String.Format("Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"" + CRLF,
file[0], Path.GetFileName(file[1])) +
"Content-Type: image/png" + CRLF + CRLF);
contentLength += b.LongLength;
if (req != null) req.Write(b, 0, b.Length);
if (File.Exists(file[1]))
{
b = File.ReadAllBytes(file[1]);
contentLength += b.LongLength;
if (req != null) req.Write(b, 0, b.Length);
}
b = Encoding.UTF8.GetBytes(CRLF);
contentLength += b.LongLength;
if (req != null) req.Write(b, 0, b.Length);
}
foreach (string[] parameter in parameters)
{
b = Encoding.UTF8.GetBytes(
"--" + boundaryString + CRLF +
String.Format("Content-Disposition: form-data; name=\"{0}\"" + CRLF, parameter[0]) +
CRLF + parameter[1] + CRLF);
contentLength += b.LongLength;
if (req != null) req.Write(b, 0, b.Length);
}
b = Encoding.UTF8.GetBytes("--" + boundaryString + "--" + CRLF);
contentLength += b.LongLength;
if (req != null) req.Write(b, 0, b.Length);
return contentLength;
}