您好,登錄后才能下訂單哦!
怎么在asp.net mvc中實現一個帶進度條的文件上傳功能?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
實現思路
ajax異步上傳文件,且開始上傳文件的時候啟動輪詢來實時獲取文件上傳進度。保存進度我采用的是memcached緩存,因為項目其他地方也用了的,所以就直接用這個啦。注意:不能使用session來保存進度,因為session是線程安全的不能實時獲取進度,可是試試httpcache或者memorycache,這兩個我沒有試過,請自行嘗試。
ps:使用websocket來實現也是不錯的,不過我沒有試過,有心的大神可以去試試。
下面貼效果圖:
實現方法如下
前端ajax上傳文件,我使用了兩種jq插件。一種是ajaxfileupload,一種是jquery.form.js(如需下載,請百度)。關于更多jQuery插件用法還可參閱本站相關專題: 《jQuery常用插件及用法總結》 。
下面的代碼是ajaxFileUpload的:
$.ajaxFileUpload ( { url: '/WxManage/Media/UploadImage', //用于文件上傳的服務器端請求地址 secureuri: false, //是否需要安全協議,一般設置為false fileElementId: 'postFile', //文件上傳域的ID type:"post", dataType: 'json', //返回值類型 一般設置為json success: function(data, status) //服務器成功響應處理函數 { CloseProgressbar();//關閉進度條 設置進度條進度為100 if (data.status == 1) { layer.msg(data.msg, { icon: 1, time: 1000 },function() { parent.location.reload(); }); } else { $("#btnUploadFile").attr("disabled", false); layer.msg(data.msg, { icon: 2, time: 1000 }); } }, error: function(data, status, e) //服務器響應失敗處理函數 { $("#btnUploadFile").attr("disabled", false); CloseProgressbar(); layer.closeAll("dialog"); layer.msg("上傳失敗", { icon: 2, time: 1000 }); } } );
后端接收文件上傳請求的action:
[HttpPost] public ActionResult UploadImage(HttpPostedFileBase postFile) { if (postFile == null) { return Json(BasicConfig.MessageConfig.Fail("上傳文件不得為空")); } try { string format = postFile.FileName.Split('.').Last();//后綴名 SaveFile(postFile); return Json(BasicConfig.MessageConfig.Success("上傳成功")); } catch (Exception ex) { return Json(BasicConfig.MessageConfig.Fail("上傳失敗")); } }
SaveFile方法是保存文件的方法,采用的是文件流方式保存以便于計算上傳進度:
核心代碼:
FileStream fs = new FileStream(fileSavePath, FileMode.Create); BinaryWriter bw = new BinaryWriter(fs); BinaryReader br = new BinaryReader(postFile[i].InputStream); int readCount = 0;//單次讀取的字節數 while ((readCount = br.Read(bufferByte, 0, readBufferSize)) > 0) { bw.Write(bufferByte, 0, readCount);//寫入字節到文件流 bw.Flush(); saveCount += readCount;//已經上傳的進度 mem.SetValue("Admin_UploadSpeed_" + Session.SessionID, (saveCount * 1.0 / totalCount).ToString("0.00"), 60);//將更新到memcached緩存中 Thread.Sleep(200);//為了看到明顯的過程故意暫停 }
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。