利用jQuery的ajax函數就能夠實現異步上傳圖片了。一開始我是想在處理程序中,直接用context.Request.Files來獲取頁面中的input file,可是不知道爲何一次獲取不了。網上說的,Form中要設置enctype="multipart/form-data"和 method="post",input file中要加runat="server",但都加了依然獲取不到。哪位大俠知道的,求指教啊。javascript
既而後臺獲取不到Input file怎麼辦呢。其實咱們上傳文件,主要是獲取到文件的物理地址就好了。只要有了這個文件地址就能夠用bitmap獲取到這個圖片了。html
剛開始我是想用ajax GET來傳送地址,但TMD若是文件名有中文就亂碼了。好在後面改爲POST後就能夠成功傳送了。java
話很少說,上代碼:jquery
前臺:ajax
<html xmlns="http://www.w3.org/1999/xhtml"> <head id="Head1" runat="server"> <title></title> <script src="Scripts/jquery-1.3.2-vsdoc2.js" type="text/javascript"></script> <script type="text/javascript"> function uploadImage() { //判斷是否有選擇上傳文件 var imgPath = $("#uploadFile").val(); if (imgPath == "") { alert("請選擇上傳圖片!"); return; } //判斷上傳文件的後綴名 var strExtension = imgPath.substr(imgPath.lastIndexOf('.') + 1); if (strExtension != 'jpg' && strExtension != 'gif' && strExtension != 'png' && strExtension != 'bmp') { alert("請選擇圖片文件"); return; } $.ajax({ type: "POST", url: "handler/UploadImageHandler.ashx", data: { imgPath: $("#uploadFile").val() }, cache: false, success: function(data) { alert("上傳成功"); $("#imgDiv").empty(); $("#imgDiv").html(data); $("#imgDiv").show(); }, error: function(XMLHttpRequest, textStatus, errorThrown) { alert("上傳失敗,請檢查網絡後重試"); } }); } </script> </head> <body> <form enctype="multipart/form-data" method="post"> <input type="file" id="uploadFile" runat="server" /> <input type="button" id="btnUpload" value="肯定" onclick="uploadImage()" /> <div id="imgDiv"> </div> </form> </body> </html>
後臺中的ashx:網絡
public void ProcessRequest (HttpContext context) { //不知道爲何獲取不到 //HttpPostedFile file = context.Request.Files["userFile"]; string filePath = context.Request["imgPath"]; string path = "UploadImgs\\"; Bitmap map = new Bitmap(filePath); string fileName = Path.GetFileName(filePath); string mapPath = context.Server.MapPath("~"); string savePath = mapPath + "\\" + path + fileName; map.Save(savePath); //上傳成功後顯示IMG文件 StringBuilder sb = new StringBuilder(); sb.Append("<img id=\"imgUpload\" src=\""+path.Replace("\\","/")+fileName+"\" />"); context.Response.Write(sb.ToString()); context.Response.End(); } public bool IsReusable { get { return false; } }
出處:http://blog.csdn.net/highplayer/article/details/7392337#html異步