asp.net core 多文件分塊同時(shí)上傳的組件
分享一個(gè)可多個(gè)文件同時(shí)上傳、斷點(diǎn)續(xù)傳,并實(shí)時(shí)反饋上傳進(jìn)度的 Asp.Net core 組件。
服務(wù)器端
引用 nuget 包:JMS.FileUploader.AspNetCore
然后啟用上傳組件:
app.UseAuthorization();
app.MapControllers();
//啟用上傳組件,并限制單個(gè)文件最大100M
app.UseJmsFileUploader(1024*102400);
app.Run();在 Controller 里面,寫(xiě)個(gè) Test 函數(shù),處理上傳的文件:
[ApiController]
[Route("[controller]/[action]")]
public class MainController : ControllerBase
{
[HttpPost]
public string Test([FromBody] object body)
{
var customHeader = Request.Headers["Custom-Header"];
//臨時(shí)文件路徑
var filepaths = Request.Headers["FilePath"];
//文件名
var filenames = Request.Headers["Name"];
return filenames;
}
}文件上傳完畢,保存在臨時(shí)文件中,Request.Headers["FilePath"] 可以讀取這些文件的路徑,如果確定要保留這些文件,用 File.Move 把它們移到你的目標(biāo)文件夾當(dāng)中;
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() {
//自定義請(qǐng)求頭
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);//設(shè)置分塊大小,默認(rèn)是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
到此這篇關(guān)于asp.net core 多文件分塊同時(shí)上傳的組件的文章就介紹到這了,更多相關(guān)asp.net core 多文件上傳內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET?Core通過(guò)Microsoft.AspNetCore.App元包簡(jiǎn)化程序集引用
這篇文章介紹了ASP.NET?Core通過(guò)Microsoft.AspNetCore.App元包簡(jiǎn)化程序集引用的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
Asp.NET 隨機(jī)碼生成基類(lèi)(隨機(jī)字母,隨機(jī)數(shù)字,隨機(jī)字母+數(shù)字)
對(duì)于需要用asp.net 字母,隨機(jī)數(shù)字,隨機(jī)字母+數(shù)字生成隨機(jī)碼的朋友用的到2008-11-11
解析ABP框架中的數(shù)據(jù)傳輸對(duì)象與應(yīng)用服務(wù)
ABP框架是基于ASP.NET的Web開(kāi)發(fā)框架,在ABP中應(yīng)用服務(wù)將領(lǐng)域邏輯暴露給展現(xiàn)層,展現(xiàn)層通過(guò)傳入數(shù)據(jù)傳輸對(duì)象參數(shù)來(lái)調(diào)用應(yīng)用服務(wù),而這里我們就來(lái)解析ABP框架中的數(shù)據(jù)傳輸對(duì)象與應(yīng)用服務(wù)2016-06-06
官網(wǎng) Ext direct包中.NET版的問(wèn)題
下載了官網(wǎng)的 Ext direct 包進(jìn)行研究,發(fā)現(xiàn)服務(wù)器端返回結(jié)果存在一點(diǎn)小問(wèn)題。2009-06-06
MVC4制作網(wǎng)站教程第二章 用戶(hù)密碼修改2.3
這篇文章主要為大家詳細(xì)介紹了MVC4制作網(wǎng)站教程,用戶(hù)密碼修改功能的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08
Visual Studio 2017 針對(duì)移動(dòng)開(kāi)發(fā)的新特性匯總
Visual Studio是世界上最好的IDE之一,下面就讓我們一起來(lái)看看Visual Studio 2017中有哪些功能使得移動(dòng)開(kāi)發(fā)變得更加容易,感興趣的朋友通過(guò)本文學(xué)習(xí)下吧2017-05-05
詳解免費(fèi)開(kāi)源的DotNet任務(wù)調(diào)度組件Quartz.NET(.NET組件介紹之五)
本篇文章主要介紹免費(fèi)開(kāi)源的DotNet任務(wù)調(diào)度組件Quartz.NET(.NET組件介紹之五),具有一定參考價(jià)值,有興趣的可以了解一下。2016-12-12

