程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)

asp.net 模擬提交有文件上傳的表單(通過http模擬上傳文件)

編輯:ASP.NET基礎
我們暫且不說如何去模擬數據,通過一個簡單的form看看當請求發生時,客戶端提交了什麼樣的數據給服務端。
下面是一個簡單的html form,兩個文本輸入框,一個文件上傳(這裡我選擇一張圖片),注意有文件上傳的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>

為了查看表單提交時,向服務端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;
}
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved