c# - 如何在 C# Web Api 中流式传输文件上传以进行数据库存储

标签 c# file-upload asp.net-web-api stream

我花了数小时研究许多发现的示例,但都没有成功,因为在 Web 表单应用程序中做起来非常简单。即上传一个或多个文件,存储在sql server中。

在网络表单 (vb.net) 中我可以这样做:

Dim fs As Stream = fileUpload1.PostedFile.InputStream
        Dim br As New BinaryReader(fs)
        Dim bytes As Byte() = br.ReadBytes(fs.Length)

        'insert the file into database
        Dim strQuery As String = "INSERT INTO files ([name], [type], [file]) VALUES (@Name, @ContentType, @Data)"
        Dim cmd As New SqlCommand(strQuery)

        cmd.Parameters.Add("@Name", SqlDbType.VarChar).Value = filename
        cmd.Parameters.Add("@ContentType", SqlDbType.VarChar).Value() = contenttype
        cmd.Parameters.Add("@Data", SqlDbType.Binary).Value = bytes

然后数据库执行语句......完成!

现在 C# Web-Api:

我现在拥有的通过 Web-Api 将上传保存到文件系统的看似不错的示例是:

public Task<IEnumerable<FileDesc>> Old()
    {
        string folderName = "uploads";
        string PATH = HttpContext.Current.Server.MapPath("~/" + folderName);
        string rootUrl = Request.RequestUri.AbsoluteUri.Replace(Request.RequestUri.AbsolutePath, String.Empty);

        if (Request.Content.IsMimeMultipartContent())
        {
            var streamProvider = new MultipartFormDataStreamProvider(PATH);
            var task = Request.Content.ReadAsMultipartAsync(streamProvider).ContinueWith<IEnumerable<FileDesc>>(t =>
            {
                if (t.IsFaulted || t.IsCanceled)
                {
                    throw new HttpResponseException(HttpStatusCode.InternalServerError); 
                }
                var fileInfo = streamProvider.FileData.Select(i =>
                {
                    var info = new FileInfo(i.LocalFileName);
                    return new FileDesc(info.Name, rootUrl + "/" + folderName + "/" + info.Name, info.Length / 1024);
                });
                return fileInfo;
            });
            return task;
        }
        else
        {
            throw new HttpResponseException(Request.CreateResponse(HttpStatusCode.NotAcceptable, "This request is not properly formatted"));
        }
    }

我似乎无法弄清楚如何获取每个多部分文件内容流,以便我可以将其发送到数据库。我看过有关 MultipartMemoryStreamProvider 和 MultipartStreamProvider 的帖子,但我还没有弄清楚如何使用它们。作为 C# 和 Web-Api 新手,我显然不知所措。

任何人都可以指导我如何将文件内容放入流中,我可以将字节发送到数据库吗?

最佳答案

当我遇到这个问题时,这是我的解决方案:

客户:

 public async Task UploadImage(byte[] image, string url)
        {
            Stream stream = new System.IO.MemoryStream(image);
            HttpStreamContent streamContent = new HttpStreamContent(stream.AsInputStream());

            Uri resourceAddress = null;
            Uri.TryCreate(url.Trim(), UriKind.Absolute, out resourceAddress);
            Windows.Web.Http.HttpRequestMessage request = new Windows.Web.Http.HttpRequestMessage(Windows.Web.Http.HttpMethod.Post, resourceAddress);
            request.Content = streamContent;

            var httpClient = new Windows.Web.Http.HttpClient();
            var cts = new CancellationTokenSource();
            Windows.Web.Http.HttpResponseMessage response = await httpClient.SendRequestAsync(request).AsTask(cts.Token);
        }

Controller :

public async Task<HttpResponseMessage> Post()
{
    Stream requestStream = await this.Request.Content.ReadAsStreamAsync();
    byte[] byteArray = null;
    using (MemoryStream ms = new MemoryStream())
    {
        await requestStream.CopyToAsync(ms);
        byteArray = ms.ToArray();
    }
    .
    .
    .
    return Request.CreateResponse(HttpStatusCode.OK);
}

关于c# - 如何在 C# Web Api 中流式传输文件上传以进行数据库存储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19105112/

相关文章:

c# - 使用 asp.net c# 解析 RSS 提要

python - 上传文件时错误请求(400),Flask

javascript - jquery 文件上传 - 粘贴时禁用上传 - 'fileuploadpaste' - 如何?

asp.net-mvc - 在 IISExpress 上通过计算机名称访问 ASP.net Web api 时出现 400 错误请求

javascript - 从 AngularJS 将复杂对象传递给 WebAPI

api - 我应该为自定义错误使用什么 HTTP 状态代码?

c# - 如何在 WP7 上播放在线广播?

c# - 使用c#创建一个弹出网页

c# - CPU利用率

python - 将 CSV 上传到 Flask 进行后台处理