javascript - 如何在 laravel 控制器中通过 Cropper Js 接收图像 blob 数据
问题描述
我正在使用cropper js和laravel,我裁剪图像并将其放入formdata并通过Jquery Ajax将其发送到Laravel控制器。我没有在控制器中获取数据的问题。但只会出错。代码如下:
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 控制器
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);
推荐阅读
- mysql - 将 Amt1 和 Amt2 值添加到上一条记录的输出列值
- flutter - Dart如何访问多维地图中的第二维
- typescript - 在 Angular 的另一个自定义验证器中检查表单控件电子邮件验证器
- fabricjs - 如何在织物 js 过滤器的片段着色器中获取像素位置和图像大小?
- netty - nghttp、curl 等 http2 客户端在流达到 64KB 后停止向基于 netty 的 http2 服务器发送更多数据
- django - Django Channels:使用消费者不工作登录到会话
- html - 如何修复降低标题高度的动画?
- boost-test - 观察测试失败消息
- reporting-services - 如何获得累积总和 SSRS 报告?
- azure - 如何在 Azure API 管理 Python SDK 中使用筛选器