gpt4 book ai didi

javascript - 如何在 laravel Controller 中通过 Cropper Js 接收图像 blob 数据

转载 作者:行者123 更新时间:2023-11-29 23:19:38 25 4
gpt4 key购买 nike

我正在使用 cropper js 和 laravel,我裁剪图像并将其放入 formdata 并通过 Jquery Ajax 将其发送到 Laravel Controller 。问题是我没有在 Controller 中获取数据。但只会得到一个错误。代码如下:

HTML

<button type="button" name="button" id="crop">Crop</button>
<img src="{{asset('public/img/img.jpg')}}" id="image" alt="" style="height: 500px;">

Jquery 和 Cropper Js 代码

<script src="{{asset('public/js/jquery.min.js')}}"></script>
<script src="{{asset('public/js/cropper.min.js')}}"></script>
<script type="text/javascript">
$(document).ready(function(){
var ele = document.getElementById('image')
var cropper = new Cropper(ele);

$('#crop').on('click', function(){
var crop = cropper.getCroppedCanvas();
crop.toBlob(function(blob){
var formdata = new FormData();
console.log(blob);
formdata.append('croppedImage', blob);

$.ajaxSetup({
headers: {
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
}
});

$.ajax("{{url('crop/save')}}", {
method: "POST",
data: formdata,
enctype: 'multipart/form-data',
cache: false,
processData: false,
contentData: false,
success(data){
console.log(data);
},
error(data){
console.log(data);
},
});
});

});
});
</script>

Laravel 路由

Route::post('crop/save', 'CropperController@save');

Laravel Controller

 public function save(Request $request){
$data = $request->croppedImage;
var_dump($data);
//Here I want to get image and upload it on the system
//But I cant Understand How
}

错误

 <br />
<b>Warning</b>: Unknown: Input variables exceeded 1000. To increase the limit change max_input_vars in php.ini. in <b>Unknown</b> on line <b>0</b><br />

请指导我,如何以正确的方式完成此操作。提前致谢。问候,

最佳答案

您需要使用 blob 数据创建一个新图像并保存它。

首先,您需要获取图像的实际内容,即:data:image/png;base64,data:image/jpeg;base64,

(您可以使用 blob 的第一部分获取扩展类型,以便稍后使用相同的扩展保存图像。)

这会做到这一点:

$base64Str = substr($data, strpos($data, ",")+1);

接下来,您需要按照 base64 对内容进行解码

$file = base64_decode($base64Str);

然后,指定保存新图像的路径。您可以使用随机生成器结合当前时间戳来为每个文件获取唯一的名称。

public function generateUniqueFileName($extension)
{
return md5(uniqid(rand(), true)) . '-' . md5(microtime()) . '.' $extension;
}

$fullPath = 'public/images/' . $this->generateUniqueFileName($extension);

最后就可以将图片存储到指定路径了:

Storage::put($fullPath, $file);

关于javascript - 如何在 laravel Controller 中通过 Cropper Js 接收图像 blob 数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51198882/

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