重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章将为大家详细讲解有关如何在asp.net core中使用webapi实现一个文件上传功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
十余年专注成都网站制作,企业网站建设,个人网站制作服务,为大家分享网站制作知识、方案,网站设计流程、步骤,成功服务上千家企业。为您提供网站建设,网站制作,网页设计及定制高端网站建设服务,专注于企业网站建设,高端网页制作,对石牌坊等多个方面,拥有丰富的网站营销经验。使用默认模板创建webapi的controller后,post请求,默认有
// POST api/values [HttpPost] public void Post([FromBody]string value) { }
请求使用了[FromBody]
标记,用来指示用请求体里获得数据。
对于文件上传请求,直接在这个Post函数里使用Request.Form.Files
是不行的,无法成功路由。
典型上传,需要设置前端发送的请求Content-Type
为multipart/form-data
,然后在控制器类加上特性修饰:
[Produces("application/json")] [Consumes("application/json", "multipart/form-data")]//此处为新增 [Route("api/[controller]")] public class FileController : Controller
指示该controller能够接受multipart/form-data
形式的数据。对应的,修改post的代码如下:
// POST: api/File [HttpPost] public TaskPost(IFormCollection files)
这里需要注意,使用的是IFormCollection。这是IForm的类型集合,实际上就是Request.Form
。
注意,很多地方写了可以使用IFormFile,直接写成
// POST: api/File [HttpPost] public TaskPost(IFormFile file)
实际测试没有办法获取到对象,file常态为null,或者是我方法不对。
然后就可以在post方法里面使用files.Files来枚举文件了,每个文件都是一个IFormFile对象,可以灵活使用FileName, Name,Length等常用属性。当然,我们也可以不带参数:
// POST: api/File [HttpPost] public TaskPost()
直接使用Request.Form.Files获得文件数据。
P.S. 对于IFormFile,与System.IO.File
对象不同,IFormFile缺少很多方法,只提供OpenReadStream()
方法,该方法返回一个stream对象。很多读文件的API都可以接受stream作为FilePath的替代。
一般的文件上传请求,不单上传文件数据,通常还需要上传其他文件信息数据(比如文件类型,上传者等等)。修改一下post方法,改成这样:
[HttpPost] public TaskPost([FromBody]string type,IFormCollection files)
将type都打包进请求,再次发送。发现......type是null。
MSDN说了,The reason for this rule is that the request body might be stored in a non-buffered stream that can only be read once.
所以,[FromBody]只能加一个,但是我这确实也只加了一个,有问题?很明显,那个IFormCollection也是默认通过[FromBody]解析的,所以正确的方法是不加[FromBody]了。
[HttpPost] public TaskPost(string type,IFormCollection files)
关于如何在asp.net core中使用webapi实现一个文件上传功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。