考虑这个base64编码图像
<img src=' />
我想将此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
});
Mvc控制器
[HttpPost]
public void SaveImage(Image file)
{
}
我认为我使用的数据类型对此无效,请告诉我该怎么做。
完整的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 & 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>
答案 0 :(得分:10)
我不是100%确定你的最终目标是什么。但下面的答案解释了如何将base64图像源字符串发送到服务器并保存。我使用从small image (22 KB size)生成的base64字符串对其进行了测试,但它确实有效。
在您的ajax调用中,您应该发送您创建的FormData
对象,而不是file
变量的值。在发送FormData对象时,请确保在进行ajax调用时使用processData
和contentType
属性。
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
});
现在,因为这是图像的基本64字符串,所以使用string
作为操作方法的参数类型。参数名称应与formdata项目键(base64Image
)匹配。您可以在action方法中从base64字符串生成一个字节数组。此外,图像源以data:image/png;base64,
开头,在您尝试转换之前需要从字符串中删除它。
以下方法接受您从客户端发送的字符串,并删除前21个字符并使用其结果(现在是有效的基本64字符串),然后从中创建一个图像并保存到{{应用程序根目录中的1}}目录,带有随机文件名。
Content/Images/
我不是100%确定默认模型绑定器可以将base64字符串绑定到图像。如果没有,您可以创建一个并将其添加到系统中的模型绑定器,然后使用Image作为参数类型。模型绑定器中的代码将非常相似(读取字符串并从中生成图像)
答案 1 :(得分:1)
我正在使用HttpPostedFileBase.cs。
[HttpPost]
public ActionResult AddDocument(ReservationDocumentsVM reservationDocumentsVM, HttpPostedFileBase postedFile)
{
if (postedFile != null)
{
string path = Server.MapPath("~/Content/Documents/");
if (!Directory.Exists(path))
{
Directory.CreateDirectory(path);
}
postedFile.SaveAs(path + Path.GetFileName(postedFile.FileName));
reservationDocumentsVM.VirtualPath = path + Path.GetFileName(postedFile.FileName);
reservationRepository.AddOrUpdateReservationDocuments(reservationDocumentsVM);
}
return RedirectToAction("Index", "Reservation");
}