我在我的应用程序中使用了cropper.js插件来裁剪图像。我可以裁剪图像。现在我正在尝试上传图片,而不是下载它们。我已经更新了显示裁剪图像的模式窗口,如下所示:
<!-- Show the cropped image in modal -->
<div class="modal fade docs-cropped" id="getCroppedCanvasModal" aria-hidden="true" aria-labelledby="getCroppedCanvasTitle" role="dialog" tabindex="-1">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
<h4 class="modal-title" id="getCroppedCanvasTitle">Cropped</h4>
</div>
<div class="modal-body"></div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal" style = "float: left;">Close</button>
<form class="form-inline" id="croperImgForm" role="form" method="post" action="${rc.getContextPath()}/module/simplewebcontent/save-image" enctype="multipart/form-data">
<label class="checkbox-inline">
<input type="checkbox" id="inlineCheckbox1" value="option1"> Save Image
</label>
<label class="checkbox-inline">
<input type="checkbox" id="inlineCheckbox2" value="option2">Save Thumbnail
</label>
<button type="submit" class="btn btn-primary" id="svImg" style = "margin-left: 10px;">Save</button>
</form>
</div>
</div>
</div>
</div><!-- /.modal -->在这里,我在底部添加了一个表单,可以选择保存图像。我正在尝试使用以下脚本来保存表单:
$("#svImg").click( function()
{
alert('button clicked');
$("#croperImgForm").submit(function(e)
{
var postData = $(this).serializeArray();
var formURL = $(this).attr("action");
$.ajax(
{
url : formURL,
type: "POST",
data : postData,
dataType : "html",
success:function(htmlData)
{
},
error: function( xhr, status, errorThrown ) {
console.log( "Error: " + errorThrown );
console.log( "Status: " + status );
console.dir( xhr );
},
});
e.preventDefault();
e.unbind();
});
});现在我从文档中发现,我应该使用以下代码来保存图像:
// Upload cropped image to server if the browser supports `canvas.toBlob`
$().cropper('getCroppedCanvas').toBlob(function (blob) {
var formData = new FormData();
formData.append('croppedImage', blob);
$.ajax('/path/to/upload', {
method: "POST",
data: formData,
processData: false,
contentType: false,
success: function () {
console.log('Upload success');
},
error: function () {
console.log('Upload error');
}
});
});但我不确定如何将此代码用作表单提交的一部分,我正尝试将其实现为ajax调用。
我还使用了Spring mvc,那么在这个图像上传的情况下,控制器方法中的参数是什么呢?
发布于 2016-08-04 03:55:31
虽然这个问题很久以前就被问到了,但我仍然分享了一个链接,指向我刚刚在上下文中发布的针对其他人的问题的解决方案。
我希望它能帮助在这个页面上找到的人。(就像我登陆后找不到解决方案一样) Crop image using Cropper.js, then upload (or display) the cropped image.
发布于 2020-08-06 22:18:33
在上面的代码中,请记住Canvas函数toBlob接受3个参数(根据Mozilla docs):
callbackmimeType例如image/jpgquality例如90因此,您可以在函数中包含mimeType和quality选项。在追加行中还包括文件名的第三个参数(具有相同的扩展名)
canvas.toBlob(function (blob) {
var formData = new FormData();
/* Add blob and file name */
formData.append('croppedImage', blob, 'file.jpg');
$.ajax('/path/to/upload', {
method: "POST",
data: formData,
processData: false,
contentType: false,
success: function () {
console.log('Upload success');
},
error: function () {
console.log('Upload error');
}
});
/* This is the important part */
}, 'image/jpeg', 0.9);发布于 2017-09-08 15:39:44
作为formData和图像源标签定义的服务器上传的github.com/fengyuanchen/cropperj Api Doc。
注意getCroppedCanvas()的以下段落:
然后,您可以将画布直接显示为图像,或者使用HTMLCanvasElement.toDataURL获取数据
,或者使用HTMLCanvasElement.toBlob获取blob并使用FormData将其上载到服务器(如果浏览器支持这些API)。
https://stackoverflow.com/questions/35068954
复制相似问题