asp.net core 多文件分塊同時上傳的組件
分享一個可多個文件同時上傳、斷點續(xù)傳,并實時反饋上傳進度的 Asp.Net core 組件。
服務器端
引用 nuget 包:JMS.FileUploader.AspNetCore
然后啟用上傳組件:
app.UseAuthorization(); app.MapControllers(); //啟用上傳組件,并限制單個文件最大100M app.UseJmsFileUploader(1024*102400); app.Run();
在 Controller 里面,寫個 Test 函數(shù),處理上傳的文件:
[ApiController] [Route("[controller]/[action]")] public class MainController : ControllerBase { [HttpPost] public string Test([FromBody] object body) { var customHeader = Request.Headers["Custom-Header"]; //臨時文件路徑 var filepaths = Request.Headers["FilePath"]; //文件名 var filenames = Request.Headers["Name"]; return filenames; } }
文件上傳完畢,保存在臨時文件中,Request.Headers["FilePath"] 可以讀取這些文件的路徑,如果確定要保留這些文件,用 File.Move 把它們移到你的目標文件夾當中;
Request.Headers["Name"] 則是讀取文件名。
前端
引入 jms-uploader 組件:
import JmsUploader from "jms-uploader"
html 元素:
<input id="file1" multiple type="file" /> <input id="file2" multiple type="file" /> <button onclick="upload()"> upload </button> <div id="info"></div>
javascript 腳本:
async function upload() { //自定義請求頭 var headers = function () { return { "Custom-Header": "test" }; }; //提交的body var dataBody = { name: "abc" }; var uploader = new JmsUploader("http://localhost:5200/main/test", [document.querySelector("#file1").files, document.querySelector("#file2").files], headers, dataBody); uploader.setPartSize(1024);//設置分塊大小,默認是102400 uploader.onUploading = function (percent, uploadedSize, totalSize) { document.querySelector("#info").innerHTML = percent + "% " + uploadedSize + "," + totalSize; }; var ret = await uploader.upload(); //上傳完畢 alert(ret); }
組件源碼地址
https://github.com/simpleway2016/JMS.FileUploader.git
到此這篇關于asp.net core 多文件分塊同時上傳的組件的文章就介紹到這了,更多相關asp.net core 多文件上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
ASP.NET?Core通過Microsoft.AspNetCore.App元包簡化程序集引用
這篇文章介紹了ASP.NET?Core通過Microsoft.AspNetCore.App元包簡化程序集引用的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07Asp.NET 隨機碼生成基類(隨機字母,隨機數(shù)字,隨機字母+數(shù)字)
對于需要用asp.net 字母,隨機數(shù)字,隨機字母+數(shù)字生成隨機碼的朋友用的到2008-11-11Visual Studio 2017 針對移動開發(fā)的新特性匯總
Visual Studio是世界上最好的IDE之一,下面就讓我們一起來看看Visual Studio 2017中有哪些功能使得移動開發(fā)變得更加容易,感興趣的朋友通過本文學習下吧2017-05-05詳解免費開源的DotNet任務調(diào)度組件Quartz.NET(.NET組件介紹之五)
本篇文章主要介紹免費開源的DotNet任務調(diào)度組件Quartz.NET(.NET組件介紹之五),具有一定參考價值,有興趣的可以了解一下。2016-12-12