asp.net 模拟提交有文件上传的表单(通过http模拟上传文件) -下载和记娱乐

2023-07-08 10:41 13次浏览 问答

我们暂且不说如何去模拟数据,通过一个简单的form看看当请求发生时,客户端提交了什么样的数据给服务端。
下面是一个简单的html form,两个文本输入框,一个文件上传(这里我选择一张图片),注意有文件上传的form的enctype属性。

代码如下:



为了查看表单提交时,向服务端post了什么数据,这里我使用fiddler来查看。
fiddler确实是个不错的工具,注意当url主机地址是localhost时fiddler捕获不到,需要再localhost后加一点(。)即可,打开fiddler,浏览带上面form的page,输入数据提交,此时在fiddler中可看到post的数据了。
下面是一部份数据的截图。
分析其中的数据不难得出,一个表单中的数据域(input type=”text”)对应的格式为
—————————–7da119c1004a6
content-disposition: form-data; name=”content”
this is a txt value
一个文件(input type=”file”)对应的格式为(通常为表单最后一个参数)
—————————–7da119c1004a6
content-disposition: form-data; name=”image0″; filename=”e:\cai\875。
jpg”
content-type: image/pjpeg
[文件内容]
结尾处是—————————–7da119c1004a6–
有了上面的数据做参考,按照其格式组织数据,post到服务端,同样可以达到html form提交的效果。
要特别注意其格式:如回车换行,差一个都可能得不到正确的响应,还有请求的content-length一定计算对。下面是一个参考:
代码
代码如下:
public string postfile(string v1,string v2, string file)
{
string boundary = “—————————” datetime。
now。ticks。tostring(“x”);
//请求
webrequest req = webrequest。create(@”http://localhost。4944/website1/getfile。
aspx”);
req。method = “post”;
req。contenttype = “multipart/form-data; boundary=” boundary;
//组织表单数据
stringbuilder sb = new stringbuilder();
sb。
append(“–” boundary);
sb。append(“\r\n”);
sb。append(“content-disposition: form-data; name=\”content\””);
sb。
append(“\r\n\r\n”);
sb。append(v1);
sb。append(“\r\n”);
sb。append(“–” boundary);
sb。
append(“\r\n”);
sb。append(“content-disposition: form-data; name=\”uploadimg\””);
sb。append(“\r\n\r\n”);
sb。
append(“v2”);
sb。append(“\r\n”);
sb。append(“–” boundary);
sb。append(“\r\n”);
sb。
append(“content-disposition: form-data; name=\”image0\”; filename=\”e:\\a。jpg\””);
sb。append(“\r\n”);
sb。
append(“content-type: image/pjpeg”);
sb。append(“\r\n\r\n”);
string head = sb。tostring();
byte[] form_data = encoding。
utf8。getbytes(head);
//结尾
byte[] foot_data = encoding。utf8。getbytes(“\r\n–” boundary “–\r\n”);
//文件
filestream filestream = new filestream(file, filemode。
open, fileaccess。read);
//post总长度
long length = form_data。length filestream。length foot_data。length;
req。
contentlength = length;
stream requeststream = req。getrequeststream();
//发送表单参数
requeststream。
write(form_data, 0, form_data。length);
//文件内容
byte[] buffer = new byte[checked((uint)math。min(4096, (int)filestream。
length))];
int bytesread = 0;
while ((bytesread = filestream。read(buffer, 0, buffer。length)) != 0)
requeststream。
write(buffer, 0, bytesread);
//结尾
requeststream。write(foot_data, 0, foot_data。length);
requeststream。
close();
//响应
webresponse pos = req。getresponse();
streamreader sr = new streamreader(pos。getresponsestream(), encoding。
utf8);
string html = sr。readtoend()。trim();
sr。close();
if (pos != null)
{
pos。
close();
pos = null;
}
if (req != null)
{
req = null;
}
return html;
}

相关推荐

网站地图