gpt4 book ai didi

javascript - 将 Base64 图像发布到 Mvc Controller

转载 作者:数据小太阳 更新时间:2023-10-29 03:49:04 25 4
gpt4 key购买 nike

考虑这个 base64 编码图像

<img src=' /> 

我想将此 src 发布到 Mvc Controller ,但是当使用 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



});

Mvc Controller

    [HttpPost]

public void SaveImage(Image file)
{

}

我认为我使用的数据类型对此无效,请建议我在这里可以做什么。

enter image description here

完整的 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>

最佳答案

我不能 100% 确定您的最终目标是什么。但是下面的答案解释了如何将 base64 图像源字符串发送到服务器并保存它。我使用从 small image (22 KB size) 生成的 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
});

既然这是图像的 base 64 字符串,请使用 string 作为操作方法的参数类型。参数名称应与您的表单数据项键 (base64Image) 匹配。您可以在操作方法中从 base64 字符串生成字节数组。此外,图像源以 data:image/png;base64, 开头,在尝试转换之前需要将其从字符串中删除。

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

[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);
}

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

关于javascript - 将 Base64 图像发布到 Mvc Controller ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46863910/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com