.Net Core创建Api进行文件上传功能

 更新时间:2022年03月09日 14:12:31   作者:冬天不懂夏的热  
这篇文章主要介绍了.Net Core创建Api进行文件上传,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1、Net Core创建api接口,用于接收外部请求,进行文件的上传

2、添加控制器类,添加如下代码:

[HttpPost]
        [Route("PostFile")]
        public String PostFile([FromForm] IFormCollection formCollection)
        {
            String result = "Fail";
            if (formCollection.ContainsKey("user"))
            {
                var user = formCollection["user"];
            }
            FormFileCollection fileCollection = (FormFileCollection)formCollection.Files;
            foreach (IFormFile file in fileCollection)
            {
                StreamReader reader = new StreamReader(file.OpenReadStream());
                String content = reader.ReadToEnd();
                String name = file.FileName;
                String filename = @"D:/Test/" + name;
                if (System.IO.File.Exists(filename))
                {
                    System.IO.File.Delete(filename);
                }
                using (FileStream fs = System.IO.File.Create(filename))
                {
                    // 复制文件
                    file.CopyTo(fs);
                    // 清空缓冲区数据
                    fs.Flush();
                }
                result = "Success";
            }
            return result;
        }

3、修改其中需要注意的点,如文件夹是否存在未做判断,需要提前创建文件夹或添加文件夹判断

4、通过postman进行接口测试,form-data数据请求方式,key选择File,value选择文件,进行提交(如图)。

5、注意问题:提交请求之后,如遇到报错返回代码413,通常是文件请求大小被限制。目前可提供以下几种解决方案,但在不同条件下生效的方式不一样,需要一一测试

方法一:在接口方法上添加特性[DisableRequestSizeLimit]

同时在startup.cs中的添加

 services.Configure<FormOptions>(x =>
            {
             x.MultipartBodyLengthLimit = 209_715_200;//最大200M
            });

方法二:在startup.cs中的添加

ervices.Configure<FormOptions>(x =>
      {
          x.ValueLengthLimit = int.MaxValue;
          x.MultipartBodyLengthLimit = int.MaxValue;
          x.MemoryBufferThreshold = int.MaxValue;
      });

如果后续有其它问题或解决方案,将在评论区进行补充。

到此这篇关于.Net Core创建Api进行文件上传的文章就介绍到这了,更多相关.Net Core文件上传内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论