分享一个 asp.net core 多文件分块同时上传的组件

分享一个可多个文件同时上传、断点续传,并实时反馈上传进度的 Asp.Net core 组件。

服务器端


引用 nuget 包:JMS.FileUploader.AspNetCore

然后启用上传组件:

            app.UseAuthorization();
            app.MapControllers();

             //启用上传组件,并限制单个文件最大100M
            app.UseJmsFileUploader(1024*102400);
            
            app.Run();

在 Controller 里面,写个 Test 函数,处理上传的文件:

    [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

  • 13
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在ASP.NET Core上载文件,您可以按照以下步骤操作: 1. 在您的控制器方法中使用`[HttpPost]`属性标记该方法。 2. 添加`[Request.Form.Files]`属性来接收提交的文件。 3. 使用`IFormFile`对象处理文件。您可以使用`CopyToAsync()`方法将文件复制到服务器文件系统中。 以下是示例代码: ```csharp [HttpPost] public async Task<IActionResult> UploadFile([FromForm] List<IFormFile> files) { long size = files.Sum(f => f.Length); // 遍历上传文件 foreach (var formFile in files) { if (formFile.Length > 0) { var filePath = Path.Combine(Directory.GetCurrentDirectory(), "wwwroot\\uploads", formFile.FileName); using (var stream = new FileStream(filePath, FileMode.Create)) { await formFile.CopyToAsync(stream); } } } return Ok(new { count = files.Count, size }); } ``` 在此示例中,我们从`[HttpPost]`属性开始,该属性表示此方法应该响应HTTP POST请求。我们还使用`[FromForm]`属性将数据传递给`files`参数。 接下来,我们使用`Sum()`方法计算上传文件的大小。然后,我们使用`foreach`循环遍历上传文件。如果文件大小大于零,则将文件保存到服务器文件系统中。 最后,我们使用`Ok()`方法返回HTTP 200 OK响应,并将上传文件的数量和大小作为JSON对象返回。 ### 回答2: ASP.NET Core 文件上传是指在开发ASP.NET Core应用程序中,实现将文件从客户端上传到服务器的功能。ASP.NET Core 提供了丰富的工具和API来处理文件上传。 要实现文件上传功能,首先需要在前端添加一个文件选择的input元素,并将其设置为文件上传的类型。然后,当用户选择文件后,可以使用JavaScript将文件发送到后端。 在后端,可以使用ASP.NET Core的控制器来处理文件上传。可以使用HttpPost特性将方法定义为POST请求,并使用FromForm特性获取从前端发送的文件。 下一步是处理接收到的文件。可以使用IFormFile接口来操作上传文件。可以通过Name属性获取文件的名称,并使用OpenReadStream方法获取文件的二进制流。 在处理文件之前,可以对文件进行一些验证和验证。例如,可以检查文件的大小、文件类型等。如果有验证错误,可以将错误信息返回给前端。 接下来,可以将接收到的文件保存到服务器的指定位置。可以使用File类的CopyToAsync方法将文件复制到指定的路径。在保存文件之前,可以为文件生成一个唯一的文件名,以避免文件名冲突。 完成文件上传后,可以向前端发送响应,确认文件上传成功。可以返回一个包含文件信息的JSON对象,或者返回一个简单的成功消息。 综上所述,ASP.NET Core 文件上传可以通过前端的文件选择和JavaScript来实现文件上传功能,并使用ASP.NET Core的控制器来接收和处理上传文件。可以对上传文件进行验证和处理,并将其保存到指定的位置。完成文件上传后,可以向前端发送响应以确认上传成功。 ### 回答3: ASP.NET Core一个开源、跨平台的框架,可以用来构建 Web 应用程序和服务。文件上传是 Web 开发中常见的功能,ASP.NET Core 提供了方便的方式来处理文件上传。 要在 ASP.NET Core 中实现文件上传,可以使用 Mvc 中的 Controller 和 View。下面是一个简单的示例: 1. 在 Controller 中,可以使用 [HttpPost] 特性来标记一个接受 Post 请求的方法。 2. 在这个方法中,需要使用 [FromForm] 特性来接受从前端传来的文件。例如,可以在方法的参数中定义一个 IFormFile 类型的参数来接收上传文件。 3. 为了接受文件上传的表单,需要在 View 文件中使用 form 标签,并设置 enctype="multipart/form-data" 属性来指示表单是用于文件上传。 4. 在表单中,可以使用 input 标签的 type="file" 来创建一个文件选择框。用户选择文件后,就可以点击提交按钮将文件上传到服务器。 5. 在 Controller 中的方法中,可以处理接收到的文件。例如,可以使用 IFormFile 类型的参数的 OpenReadStream() 方法来获取文件的流,然后将文件保存到服务器。 需要注意的是,文件上传涉及到服务器端的文件处理和安全问题。在实际应用中,我们需要对文件的类型、大小、保存路径等进行限制,以及对上传文件进行合法性校验和防止文件上传漏洞攻击的处理。 总结来说,ASP.NET Core 提供了方便的方式来实现文件上传功能。通过使用 Controller 和 View,可以很容易地将文件从前端上传到服务器,并对文件进行处理和保存。同时,为了确保安全和合法性,我们需要对文件进行校验和防御措施。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值