微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-core-webapi – 在asp.net核心web api中上传多部分/表单数据文件

如何在asp.net核心web api中上传多部分表单数据文件?是否可以在单个POST中同时POST JSON和图像?

解决方法

更新 – .net核心2.0

使用.net核心,您可以利用新的IFormFile接口在同一帖子中上传图像和属性.例如:

[HttpPost("content/upload-image")]
public async Task<IActionResult> UploadImage(MyFile upload)

MyFile类看起来像:

public class MyFile
{
    public string userId { get; set; }        
    public IFormFile File { get; set; }
    // Other properties
}

您可以按如下方式访问属性文件

var file = upload.File // This is the IFormFile file
var param = upload.userId // param

要将文件保留/保存到磁盘,您可以执行以下操作:

using (var stream = new FileStream(path,FileMode.Create))
{
    await file.File.copyToAsync(stream);
}

.NET Framework

是的.根据您正在使用的客户端框架,您可以为内容类型 – 多部件配置Web API,然后执行以下操作:

[HttpPost]
[Route("content/upload-image")]       
public async Task<HttpResponseMessage> Post()
{
    if (!Request.Content.IsMimeMultipartContent())
    {
        throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
    }           
    // enter code here
}

定义并设置保存图像的目录.

var root = HttpContext.Current.Server.MapPath("~/Content/Images/");
if (!Directory.Exists(root))
{
    Directory.CreateDirectory(root);
}

设置StreamProvider并尝试获取模型数据,这是您提到的JSON.

var streamProvider = new MultipartFormDataStreamProvider(root);
var result =
    await Request.Content.ReadAsMultipartAsync(streamProvider);
if (result.FormData["model"] == null)
{
    throw new HttpResponseException(HttpStatusCode.BadRequest);
}

现在访问请求中的文件.

try
{
    // Deserialize model data to your own DTO
    var model = result.FormData["model"];
    var formDto = JsonConvert
        .DeserializeObject<MyDto>(model,new IsoDateTimeConverter());
    var files = result.FileData.ToList();                
    if (files != null)
    {
        foreach (var file in files)
        {
            // Do anything with the file(s)
        }
    }
}

原文地址:https://www.jb51.cc/aspnet/248609.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐