如何上传图片和POST数据到的Azure移动服务ApiController终点? [英] How can I upload an image and POST data to an Azure Mobile Services ApiController endpoint?

查看:386
本文介绍了如何上传图片和POST数据到的Azure移动服务ApiController终点?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想上传图片的 POST 表格数据(虽然理想情况下,我想它是 JSON )到端点在我的的Azure移动服务应用程序。

I am trying to upload an image and POST form data (although ideally I'd like it to be json) to an endpoint in my Azure Mobile Services application.

我有 ApiController 方法:

[HttpPost]
[Route("api/upload/{databaseId}/{searchingEnabled}/{trackingEnabled}")]
public async Task<IHttpActionResult> Upload(string databaseId, string searchingEnabled, string trackingEnabled, [FromBody]string metadata) {

    if (!Request.Content.IsMimeMultipartContent()) {
        return BadRequest("No image is uploaded.");
    }
    else {
        var provider = new MultipartMemoryStreamProvider();
        await Request.Content.ReadAsMultipartAsync(provider);
        foreach (var file in provider.Contents) {
             // Process each image uploaded
        }
    }
}

这只能当我删除 [FromBody]字符串的元数据,但它的伟大工程。

当包含 [FromBody]字符串的元数据(如上),我得到的错误:

When [FromBody]string metadata is included (as above), I get the error:

The request entity's media type 'multipart/form-data' is not supported for this resource.

然而的,我想 POST 其他(这可能会很长,所以我不想把它放在URI)。

However, I would like to POST additional metadata (which can be long, so I don't want to put it in the Uri).

我怎样才能保持文件上传的逻辑,也是 POST 附加字符串数据到我的控制器?

How can I keep the file upload logic, and also POST additional string data to my controller?

我使用的Azure移动服务,因此这code是内部的 System.Web.Http.ApiController (如果该事项)。

I am using Azure Mobile Services, so this code is inside an System.Web.Http.ApiController (if that matters).

推荐答案

我所做的previously是使客户发布同时包含元数据和实际文件的JSON模式。每个文件都是那么一个base64连接的实际文件内容的codeD字符串。下面code应该能够处理数据的URI +的base64。

What I've done previously is to make the client post a json model which contains both the metadata and the actual files. Each file is then a base64 encoded string of the actual file content. The below code should be able to handle data uri + base64.

我的前端应用程序是通过使用<$ C $使用JavaScript文件API来获取到的FileReader 对象,它可以返回一个Base64(数据URI)的参考字符串C> readAsDataURL 方法。它基本上做这样的事情:

My frontend app is using the javascript File API to get a reference to a FileReader object which can return a base64 (data uri) string by using the readAsDataURL method. It's basically doing something like this:

var attachment = {};

function loadAttachmentFromFileInput(element) {
    var file = element.files[0];

    var reader = new FileReader();

    reader.onload = function(e) {
        var result = reader.result;

        attachment = {
            data: result,
            filename: file.name,
            type: file.type,
            size: file.size
            }
    }

    reader.readAsDataURL(file);    
}

我要建设一个 POST 模式,将导致以下JSON内容:

I'm then building a POST model which results in the following json content:

{
  "messageId": 1,
  "foo": "bar",
  "bar": "foo",
  "attachments": [{
    "filename": "stackoverflow.jpg",
    "data": "",
    "type": "image/jpeg"
}]
}

控制器看起来是这样的:

Controller looks like this:

[Route("api/messages/{messageId:guid}")]
public async Task<IHttpActionResult> Post(Guid messageId, CreateMessageAttachments model)
{
    // Access to all properties in your post model
    Trace.WriteLine(model.Foo);
    Trace.WriteLine(model.Bar);

    foreach (var attachment in model.Attachments)
    {
        // Do what you need to with the bytes from the uploaded attachments
        var bytes = attachment.GetByteArray();
    }

    return Ok();
}

然后,我有以下型号支持控制器:

Then I have the following models to support the controller:

public class CreateMessageAttachments
{
    public Guid MessageId { get; set; }
    public string Foo { get; set; }
    public string Bar { get; set; }
    public IList<CreateAttachment> Attachments { get; set; }
}

public class CreateAttachment
{
    public string Data { get; set; }
    public string Filename { get; set; }
    public string Type { get; set; }

    public string GetBase64()
    {
        if (string.IsNullOrWhiteSpace(Data))
            return null;

        var index = Data.LastIndexOf("base64");

        if (index == -1)
            return Data;

        return Data.Substring(index + 7);
    }

    public byte[] GetByteArray()
    {
        try
        {
            var base64 = GetBase64();

            if (string.IsNullOrWhiteSpace(base64))
                return null;

            return Convert.FromBase64String(base64);
        }
        catch
        {
            return null;
        }

    }
}

这篇关于如何上传图片和POST数据到的Azure移动服务ApiController终点?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆