【问题标题】:How to upload blob and convert to image in webapi如何在 webapi 中上传 blob 并转换为图像
【发布时间】:2018-11-08 07:17:44
【问题描述】:

我正在尝试将从图像创建的 blob 上传到我的服务器,然后将 blob 转换为图像并将其保存在 C# webapi 中。我创建了一个画布来存储我的图像并将其转换为 base64 文件。下面是我的javascript代码。

    var blob = canvas.toDataURL("image/jpeg"); // This will save your image as a 
                //jpeg file in the base64 format.
                var jpegFile64 = blob.replace(/^data:image\/(png|jpeg);base64,/, "");
                var jpegBlob = base64ToBlob(jpegFile64, 'image/jpeg');
                var data = new FormData();
                data.append("mypic", jpegBlob, "thisimage.jpg");
                var oReq = new XMLHttpRequest();
                oReq.open("POST", "http://localhost:52704/api/uploadfile/myfile.jpg/", true);
                oReq.onload = function (oEvent) {
                     alert(this.responseText);
                     };
                oReq.send(data);
      }

       function base64ToBlob(base64, mime) {
        mime = mime || '';
        var sliceSize = 1024;
        var byteChars = window.atob(base64);
        var byteArrays = [];

        for (var offset = 0, len = byteChars.length; offset < len; offset += sliceSize) {
            var slice = byteChars.slice(offset, offset + sliceSize);

            var byteNumbers = new Array(slice.length);
            for (var i = 0; i < slice.length; i++) {
                byteNumbers[i] = slice.charCodeAt(i);
            }

            var byteArray = new Uint8Array(byteNumbers);

            byteArrays.push(byteArray);
        }

        return new Blob(byteArrays, { type: mime });
    }

下面是我用 C# 编写的 webapi 服务器代码。该文件保存为“thisimage.jpg”,附加在我的 javascript 中的 FormData 中。

      public string Post(string id)
    {
        string result = null;
        var httpRequest = HttpContext.Current.Request;
        string count = httpRequest.Files.Count.ToString();

            if (httpRequest.Files.Count > 0)
            {
                var postedFile = httpRequest.Files[0];
                var filePath = "c:/inetpub/wwwroot/pics/" + postedFile.Filename;
                postedFile.SaveAs(filePath);
     //  File is saved as "thisimage.jpg" 
            result = "File saved as " + filePath;
            }

        else
        {
            result = "Upload failed";
        }
        return result;
    }

【问题讨论】:

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


    【解决方案1】:

    现在可以了!我的张贴文件地址中有错字。所以现在它可以工作了,这是一个如何使用 Webapi 和 javascript 将 blob 上传到服务器的示例。我在帖子中添加了一个字符串值 id 并用它为文件命名。

    【讨论】:

    • FormData.append 中有第三个参数是 Blob 的文件名。
    • 感谢您将其作为示例,这正是我想要的!
    猜你喜欢
    • 2021-12-06
    • 1970-01-01
    • 2012-12-29
    • 2019-07-25
    • 1970-01-01
    • 2021-07-19
    • 1970-01-01
    • 2021-10-10
    • 1970-01-01
    相关资源
    最近更新 更多