asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)
更新時(shí)間:2010年02月26日 16:03:20 作者:
通過HTTP模擬GET或POST請(qǐng)求,提交數(shù)據(jù)到服務(wù)端獲取響應(yīng),比較常見些;但如上傳文件到服務(wù)端,使用html form當(dāng)然簡單了,而因環(huán)境所限有時(shí)需要使用模擬方法去提交有附件(文件上傳)的表單。
我們暫且不說如何去模擬數(shù)據(jù),通過一個(gè)簡單的form看看當(dāng)請(qǐng)求發(fā)生時(shí),客戶端提交了什么樣的數(shù)據(jù)給服務(wù)端。
下面是一個(gè)簡單的html form,兩個(gè)文本輸入框,一個(gè)文件上傳(這里我選擇一張圖片),注意有文件上傳的form的enctype屬性。
<form action="sql.aspx" method="post" enctype="multipart/form-data">
<input id="Text1" name="content" type="text" /><br />
<input id="Text2" name="uploadImg" type="text" /><br />
<input id="File1" type="file" name="image0" /><br />
<input id="Submit1" type="submit" value="submit" />
</form>
為了查看表單提交時(shí),向服務(wù)端post了什么數(shù)據(jù),這里我使用Fiddler來查看。Fiddler確實(shí)是個(gè)不錯(cuò)的工具,注意當(dāng)url主機(jī)地址是localhost時(shí)Fiddler捕獲不到,需要再localhost后加一點(diǎn)(.)即可,打開Fiddler,瀏覽帶上面form的page,輸入數(shù)據(jù)提交,此時(shí)在Fiddler中可看到post的數(shù)據(jù)了。下面是一部份數(shù)據(jù)的截圖。

分析其中的數(shù)據(jù)不難得出,一個(gè)表單中的數(shù)據(jù)域(input type="text")對(duì)應(yīng)的格式為
-----------------------------7da119c1004a6
Content-Disposition: form-data; name="content"
this is a txt value
一個(gè)文件(input type="file")對(duì)應(yīng)的格式為(通常為表單最后一個(gè)參數(shù))
-----------------------------7da119c1004a6
Content-Disposition: form-data; name="image0"; filename="E:\CAI\875.jpg"
Content-Type: image/pjpeg
[文件內(nèi)容]
結(jié)尾處是-----------------------------7da119c1004a6--
有了上面的數(shù)據(jù)做參考,按照其格式組織數(shù)據(jù),post到服務(wù)端,同樣可以達(dá)到html form提交的效果。要特別注意其格式:如回車換行,差一個(gè)都可能得不到正確的響應(yīng),還有請(qǐng)求的Content-Length一定計(jì)算對(duì)。下面是一個(gè)參考:
代碼
public string POSTfile(string v1,string v2, string file)
{
string boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x");
//請(qǐng)求
WebRequest req = WebRequest.Create(@"http://localhost.:4944/WebSite1/getfile.aspx");
req.Method = "POST";
req.ContentType = "multipart/form-data; boundary=" + boundary;
//組織表單數(shù)據(jù)
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);
//結(jié)尾
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();
//發(fā)送表單參數(shù)
requestStream.Write(form_data, 0, form_data.Length);
//文件內(nèi)容
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);
//結(jié)尾
requestStream.Write(foot_data, 0, foot_data.Length);
requestStream.Close();
//響應(yīng)
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;
}
下面是一個(gè)簡單的html form,兩個(gè)文本輸入框,一個(gè)文件上傳(這里我選擇一張圖片),注意有文件上傳的form的enctype屬性。
復(fù)制代碼 代碼如下:
<form action="sql.aspx" method="post" enctype="multipart/form-data">
<input id="Text1" name="content" type="text" /><br />
<input id="Text2" name="uploadImg" type="text" /><br />
<input id="File1" type="file" name="image0" /><br />
<input id="Submit1" type="submit" value="submit" />
</form>
為了查看表單提交時(shí),向服務(wù)端post了什么數(shù)據(jù),這里我使用Fiddler來查看。Fiddler確實(shí)是個(gè)不錯(cuò)的工具,注意當(dāng)url主機(jī)地址是localhost時(shí)Fiddler捕獲不到,需要再localhost后加一點(diǎn)(.)即可,打開Fiddler,瀏覽帶上面form的page,輸入數(shù)據(jù)提交,此時(shí)在Fiddler中可看到post的數(shù)據(jù)了。下面是一部份數(shù)據(jù)的截圖。

分析其中的數(shù)據(jù)不難得出,一個(gè)表單中的數(shù)據(jù)域(input type="text")對(duì)應(yīng)的格式為
-----------------------------7da119c1004a6
Content-Disposition: form-data; name="content"
this is a txt value
一個(gè)文件(input type="file")對(duì)應(yīng)的格式為(通常為表單最后一個(gè)參數(shù))
-----------------------------7da119c1004a6
Content-Disposition: form-data; name="image0"; filename="E:\CAI\875.jpg"
Content-Type: image/pjpeg
[文件內(nèi)容]
結(jié)尾處是-----------------------------7da119c1004a6--
有了上面的數(shù)據(jù)做參考,按照其格式組織數(shù)據(jù),post到服務(wù)端,同樣可以達(dá)到html form提交的效果。要特別注意其格式:如回車換行,差一個(gè)都可能得不到正確的響應(yīng),還有請(qǐng)求的Content-Length一定計(jì)算對(duì)。下面是一個(gè)參考:
代碼
復(fù)制代碼 代碼如下:
public string POSTfile(string v1,string v2, string file)
{
string boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x");
//請(qǐng)求
WebRequest req = WebRequest.Create(@"http://localhost.:4944/WebSite1/getfile.aspx");
req.Method = "POST";
req.ContentType = "multipart/form-data; boundary=" + boundary;
//組織表單數(shù)據(jù)
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);
//結(jié)尾
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();
//發(fā)送表單參數(shù)
requestStream.Write(form_data, 0, form_data.Length);
//文件內(nèi)容
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);
//結(jié)尾
requestStream.Write(foot_data, 0, foot_data.Length);
requestStream.Close();
//響應(yīng)
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;
}
您可能感興趣的文章:
- asp.net獲取HTML表單File中的路徑的方法
- asp.net 中將表單提交到另一頁 Code-Behind(代碼和html在不同的頁面)
- asp.net利用后臺(tái)實(shí)現(xiàn)直接生成html分頁的方法
- Asp.net動(dòng)態(tài)生成html頁面的方法分享
- 使用ASP.NET模板生成HTML靜態(tài)頁面的五種方案
- jquery獲取ASP.NET服務(wù)器端控件dropdownlist和radiobuttonlist生成客戶端HTML標(biāo)簽后的value和text值
- ASP.net(c#) 生成html的幾種解決方案[思路]
- 使用ASP.NET 2.0 CSS 控件適配器生成CSS友好的HTML輸出
- asp.net生成HTML
- 利用ASP.NET技術(shù)動(dòng)態(tài)生成HTML頁面
- asp.net 防止用戶通過后退按鈕重復(fù)提交表單
- ASP.NET中實(shí)現(xiàn)把form表單元素轉(zhuǎn)為實(shí)體對(duì)象或集合
- asp.net動(dòng)態(tài)生成HTML表單的方法
相關(guān)文章
asp.net中一個(gè)linq分頁實(shí)現(xiàn)代碼
asp.net中一個(gè)linq分頁實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-12-12ASP.NET AJAX 4.0的模版編程(Template Programming)介紹
不過當(dāng)我評(píng)估ASP.NET AJAX 4.0的時(shí)候,我確實(shí)被它的特征給震住了。新的特征完全專注于瀏覽器技術(shù),比如XHTML和javascript。 我非常欽佩ASP.NET AJAX小組。2009-07-07C#精髓 GridView72大絕技 學(xué)習(xí)gridview的朋友必看
C#精髓 GridView72大絕技 學(xué)習(xí)gridview的朋友可以參考下。2009-10-10.Net使用分表分庫框架ShardingCore實(shí)現(xiàn)多字段分片
本文詳細(xì)講解了.Net使用分表分庫框架ShardingCore實(shí)現(xiàn)多字段分片的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12.Net彈性和瞬態(tài)故障處理庫Polly實(shí)現(xiàn)彈性策略
這篇文章介紹了.Net彈性和瞬態(tài)故障處理庫Polly實(shí)現(xiàn)彈性策略的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06.NET 與樹莓派WS28XX 燈帶的顏色漸變動(dòng)畫效果的實(shí)現(xiàn)
所謂顏色漸變動(dòng)畫,首先,你要確定兩種顏色——起始色和最終色,比如從綠色變成紅色,綠色是起始,紅色是終點(diǎn)。這篇文章主要介紹了.NET 與樹莓派WS28XX 燈帶的顏色漸變動(dòng)畫,需要的朋友可以參考下2021-12-12