asp.net core webapi文件上傳功能的實(shí)現(xiàn)
最近開發(fā)一個(gè)新項(xiàng)目,使用了asp.net core 2.0,采用webapi開發(fā)后臺(tái),postgresql為數(shù)據(jù)庫。最先來的問題就是上傳文件的問題。
POST文件的一些坑
使用默認(rèn)模板創(chuàng)建webapi的controller后,post請(qǐng)求,默認(rèn)有
// POST api/values [HttpPost] public void Post([FromBody]string value) { }
請(qǐng)求使用了[FromBody]
標(biāo)記,用來指示用請(qǐng)求體里獲得數(shù)據(jù)。
對(duì)于文件上傳請(qǐng)求,直接在這個(gè)Post函數(shù)里使用Request.Form.Files
是不行的,無法成功路由。
典型上傳,需要設(shè)置前端發(fā)送的請(qǐng)求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
形式的數(shù)據(jù)。對(duì)應(yīng)的,修改post的代碼如下:
// POST: api/File [HttpPost] public Task<ActionResult> Post(IFormCollection files)
這里需要注意,使用的是IFormCollection。這是IForm的類型集合,實(shí)際上就是Request.Form
。
注意,很多地方寫了可以使用IFormFile,直接寫成
// POST: api/File [HttpPost] public Task<ActionResult> Post(IFormFile file)
實(shí)際測試沒有辦法獲取到對(duì)象,file常態(tài)為null,或者是我方法不對(duì)。
然后就可以在post方法里面使用files.Files來枚舉文件了,每個(gè)文件都是一個(gè)IFormFile對(duì)象,可以靈活使用FileName, Name,Length等常用屬性。當(dāng)然,我們也可以不帶參數(shù):
// POST: api/File [HttpPost] public Task<ActionResult> Post()
直接使用Request.Form.Files獲得文件數(shù)據(jù)。
P.S. 對(duì)于IFormFile,與System.IO.File
對(duì)象不同,IFormFile缺少很多方法,只提供OpenReadStream()
方法,該方法返回一個(gè)stream對(duì)象。很多讀文件的API都可以接受stream作為FilePath的替代。
同時(shí)上傳其他數(shù)據(jù)
一般的文件上傳請(qǐng)求,不單上傳文件數(shù)據(jù),通常還需要上傳其他文件信息數(shù)據(jù)(比如文件類型,上傳者等等)。修改一下post方法,改成這樣:
[HttpPost] public Task<ActionResult> Post([FromBody]string type,IFormCollection files)
將type都打包進(jìn)請(qǐng)求,再次發(fā)送。發(fā)現(xiàn)......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]只能加一個(gè),但是我這確實(shí)也只加了一個(gè),有問題?很明顯,那個(gè)IFormCollection也是默認(rèn)通過[FromBody]解析的,所以正確的方法是不加[FromBody]了。
[HttpPost] public Task<ActionResult> Post(string type,IFormCollection files)
后記
回想起當(dāng)年做WebService的時(shí)候,上傳文件寫的
多平臺(tái)上傳
,感觸頗多,以前是轉(zhuǎn)碼到base64,通過string發(fā)送,現(xiàn)在是直接類型識(shí)別...
到此這篇關(guān)于asp.net core webapi文件上傳的文章就介紹到這了,更多相關(guān)asp.net core webapi文件上傳內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解.NET6下的Modbus通訊和數(shù)據(jù)庫記錄
本文主要介紹了.NET6下的Modbus通訊和數(shù)據(jù)庫記錄,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04ASP.NET網(wǎng)站導(dǎo)航及導(dǎo)航控件如何使用
這篇文章主要介紹了ASP.NET網(wǎng)站導(dǎo)航及導(dǎo)航控件如何使用,需要的朋友可以參考下2015-09-09ASP.NET?Core項(xiàng)目使用xUnit進(jìn)行單元測試
這篇文章介紹了ASP.NET?Core項(xiàng)目使用xUnit進(jìn)行單元測試的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03ASP.NET中Application全局對(duì)象用法實(shí)例淺析
這篇文章主要介紹了ASP.NET中Application全局對(duì)象用法,較為詳細(xì)的分析了ASP.NET中Application全局對(duì)象的功能、定義及使用中的相關(guān)注意事項(xiàng),需要的朋友可以參考下2015-06-06SQL為查詢的結(jié)果加上序號(hào)(ROW_NUMBER) 合并多個(gè)查詢結(jié)果
SQL為查詢的結(jié)果加上序號(hào)(ROW_NUMBER) 合并多個(gè)查詢結(jié)果2010-03-03