我正在使用Insomnia来测试API,但Postman也是如此。
我想使用以下控制器测试文件上传:
public async Task<IActionResult> Post([FromForm]IFormFile File)
如果我将请求设置为多部分请求:
它有效。
但是,如果我将其设置为二进制文件:
我不知道如何获取数据。怎么办呢?
另外,在控制器方法的签名中,如果我将[FromForm]更改为[FromBody],我就没有获取数据。
有人可以为我澄清这个吗?
答案 0 :(得分:14)
正如您已经注意到的那样,在Postman / Insomnia中使用binary file
选项并不是标准方式。通过RESTful API上传文件有三种不同的方法,你必须选择一种。
我已经包含了将上传的文件内容读取到字符串并输出的代码片段 - 尝试发送文本文件,您应该在200响应中获取该文件的内容。
表单数据上传
这是最流行/众所周知的上传方法,将您发送的数据格式化为一组键/值对。您通常需要在请求中指定Content-Type
到multipart/form-data
,然后在MVC中使用[FromForm]
属性将值绑定到变量。此外,您可以使用内置的IFormFile
类来访问上传的文件。
[HttpPost]
public async Task<IActionResult> PostFormData([FromForm] IFormFile file)
{
using (var sr = new StreamReader(file.OpenReadStream()))
{
var content = await sr.ReadToEndAsync();
return Ok(content);
}
}
正文上传
您可以以MVC理解的格式发送正文,例如JSON,并将文件嵌入其中。通常,文件内容将使用Base64或其他编码进行编码,以防止出现字符编码/解码问题,尤其是在发送图像或二进制数据时。 E.g。
{
"file": "MTIz"
}
然后在控制器中指定[FromBody]
,并使用class进行模型反序列化。
[HttpPost]
public IActionResult PostBody([FromBody] UploadModel uploadModel)
{
var bytes = Convert.FromBase64String(uploadModel.File);
var decodedString = Encoding.UTF8.GetString(bytes);
return Ok(decodedString);
}
// ...
public class UploadModel
{
public string File { get; set; }
}
使用大型和非文本文件时,JSON请求变得笨拙且难以阅读。
二进制文件
这里的关键点是您的文件是整个请求。该请求不包含任何其他信息,以帮助MVC将值绑定到代码中的变量。因此,要访问该文件,您需要阅读Body
中的Request
。
[HttpPost]
public async Task<IActionResult> PostBinary()
{
using (var sr = new StreamReader(Request.Body))
{
var body = await sr.ReadToEndAsync();
return Ok(body);
}
}
答案 1 :(得分:0)
除上述内容外,如果将多部分文件转换为base64String,则可以参考以下内容:
if (File.Length> 0)
{
using (var ms = new MemoryStream())
{
File.CopyTo(ms);
var fileBytes = ms.ToArray();
string s = Convert.ToBase64String(fileBytes);
}
}
注意:我正在将此代码用于.NET CORE 2.1