将Base64图像发布到Mvc控制器

TAH*_*URI 9 javascript c# asp.net ajax asp.net-mvc

考虑这个base64编码图像

<img src=' /> 
Run Code Online (Sandbox Code Playgroud)

我想将此src发布到Mvc控制器,但是当使用ajax发布时获取null是post方法.

    var file = document.getElementById("base64image").src;

        var formdata = new FormData();
        formdata.append("base64image", file);

        $.ajax({
            url: "http://localhost:26792/home/SaveImage",
            type: "POST",
            data: file



        });
Run Code Online (Sandbox Code Playgroud)

Mvc控制器

    [HttpPost]

    public void SaveImage(Image file)
    {

    }
Run Code Online (Sandbox Code Playgroud)

我认为我使用的数据类型对此无效,请告诉我该怎么做.

在此输入图像描述

完整的Html代码

<!doctype html>

<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>WebcamJS Test Page</title>
<style type="text/css">
    body { font-family: Helvetica, sans-serif; }
    h2, h3 { margin-top:0; }
    form { margin-top: 15px; }
    form > input { margin-right: 15px; }
    #results { float:right; margin:20px; padding:20px; border:1px solid; background:#ccc; }
</style>
</head>
<body>
<div id="results">Your captured image will appear here...</div>

<h1>WebcamJS Test Page</h1>
<h3>Demonstrates simple 320x240 capture &amp; display</h3>

<div id="my_camera"></div>

<!-- First, include the Webcam.js JavaScript Library -->
<script type="text/javascript" src="../webcam.min.js"></script>

<!-- Configure a few settings and attach camera -->
<script language="JavaScript">
    Webcam.set({
        width: 320,
        height: 240,
        image_format: 'jpeg',
        jpeg_quality: 90
    });
    Webcam.attach( '#my_camera' );
</script>

<!-- A button for taking snaps -->
<form>
    <input type=button id="takeshot" value="Take Snapshot" onClick="take_snapshot()">
</form>

<!-- Code to handle taking the snapshot and displaying it locally -->
<script language="JavaScript">

    window.onload = function () {

        setInterval(function () { take_snapshot() }, 5000);
    }
    function take_snapshot() {
        // take snapshot and get image data
        Webcam.snap( function(data_uri) {
            // display results in page
            document.getElementById('results').innerHTML = 
                '<h2>Here is your image:</h2>' + 
                '<img id="base64image" src="' + data_uri + '"/>';
        });



        var file = document.getElementById("base64image").src;

        var formdata = new FormData();
        formdata.append("base64image", file);

        $.ajax({
            url: "http://localhost:26792/home/SaveImage",
            type: "POST",
            data: file



        });
        //var ajax = new XMLHttpRequest();
        //ajax.addEventListener("load", function (event) { uploadcomplete(event); }, false);
        //ajax.open("POST", "http://localhost:26792/home/SaveImage");

        //ajax.send(formdata);
    }
    </script>
   <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>


 </body>
 </html>
Run Code Online (Sandbox Code Playgroud)

Shy*_*yju 11

我不是100%确定你的最终目标是什么.但下面的答案解释了如何将base64图像源字符串发送到服务器并保存.我使用从小图像(22 KB大小)生成的base64字符串测试它并且它工作.

在你的ajax调用中,你应该发送FormData你创建的对象,而不是file变量的值.在发送FormData对象时,还要确保在进行ajax调用时使用processDatacontentType属性.

var file = document.getElementById("base64image").src;

var formdata = new FormData();
formdata.append("base64image", file);

$.ajax({
    url: "@Url.Action("SaveImage")",
    type: "POST",
    data: formdata,
    processData: false,
    contentType: false
});
Run Code Online (Sandbox Code Playgroud)

现在,由于这是图像的基本64字符串,因此请将其string用作操作方法的参数类型.参数名称应与formdata项目键(base64Image)匹配.您可以在action方法中从base64字符串生成一个字节数组.此外,data:image/png;base64,在您尝试转换之前,图像源首先需要从字符串中删除.

下面的方法接受你从客户端发送的字符串,并删除前21个字符并使用它的结果(现在是一个有效的base 64字符串),然后从中创建一个图像并保存到Content/Images/app根目录中随机文件名.

[HttpPost]
public void SaveImage(string base64image)
{
    if (string.IsNullOrEmpty(base64image))
        return;

    var t = base64image.Substring(22);  // remove data:image/png;base64,

    byte[] bytes = Convert.FromBase64String(t);

    Image image;
    using (MemoryStream ms = new MemoryStream(bytes))
    {
        image = Image.FromStream(ms);
    }
    var randomFileName = Guid.NewGuid().ToString().Substring(0, 4) + ".png";
    var fullPath = Path.Combine(Server.MapPath("~/Content/Images/"), randomFileName);
    image.Save(fullPath, System.Drawing.Imaging.ImageFormat.Png);
}
Run Code Online (Sandbox Code Playgroud)

我不是100%确定默认模型绑定器可以将base64字符串绑定到图像.如果没有,您可以创建一个并将其添加到系统中的模型绑定器,然后使用Image作为参数类型.模型绑定器中的代码将非常相似(读取字符串并从中生成图像)