男色经典
男色经典
  • 发布:2020-03-27 02:25
  • 更新:2023-09-19 22:03
  • 阅读:5668

解决了cropper裁切图片toDataURL()跨域报错的问题,记录一下。

分类:HTML5+

那些说 img.crossOrigin = 'anonymous' 能解决问题请绕道,害我纠结了一天。

这两天在弄头像裁切,发现toDataURL()不能用了,我以前根本没用过这个功能,所以不太了解,上网找了好些个例子,发现都不能用,我以为是发布者发的代码有问题,等我找了好多个DEMO后,发现都不能用,于是开始一行一行的读代码,试图找出问题所在。

等我把代码读到toDataURL() 这一行的时候,发现执行错误的问题就在这里,了解了一下,发现是WKwebview创建的时候跨域造成的, 而IOS从今年4月份也不再支持UIWebview了!而网络上的大神们给出的 img.crossOrigin = 'anonymous' 根本不管用,因为APP裁切的图片基本上都是拍照或本地相册,所以不存在这个问题。

于是,我找到了另一个图片裁切的插件,jquery photoclip ,发现这个插件能用,而且没有报跨域的错误,而且上传很方便,于是我懵了,都是jquery的插件,为啥一个能用一个不能用呢?

于是我读了读两个插件的源码,发现一个重要的不同:
crepper 是利用canvas直接读取img文件,尝试转成base64的时候出错,这个目前无解,官方给出的解决方案是用plus先转成base64再使用,还给出了例子,结果我是H5+的项目,没有尝试成功。
photoclip 是使用一个input file 控件,先选择本机文件,然后利用file控件读取用户上传的文件信息,然后再转成base64进行处理。

我想想算了,就用photoclip吧,能用就行,结果发现这破东西根本不能用,缩方功能做的和shi一样,根本不行,跳来跳去,抖来抖去的,而且要先点击input选择文件才行,用户体验非常不好。

于是我想到了一个解决方案:
为什么不用photoclip 读取文件的思路来解决cropper的跨域问题呢?各取所长。

于是想着怎么把一个本地图径的path地址转换成file控件里的文件内容,而且要直接调用相机,而不是文件选择框。

最后形成一个完美的解决方案:
Step1 调用相机拍照形成本地文件。
Step2 利用fileReader把文件读出来,转换成Base64。
Step3 把Base64的图片利用cropper渲染到canvas上进行裁切。
Step4 再次使用 cropper.toDataURL()方法的时候,就不再全报错,顺利解决!

我现在的代码因为各种尝试弄的很乱,就不发了,发了你们看的也费劲,好多冗余代码,等我清理好之后,可以发布上来和大家共享。

6 关注 分享
y***@163.com DCloud_云服务_Mal 幽壑潜蛟 1***@qq.com 2***@qq.com l***@163.com

要回复文章请先登录注册

caicaixiaoya

caicaixiaoya

回复 男色经典 :
大佬,请问可以看看代码吗,$image.cropper('getCroppedCanvas').toDataURL()总是报错。邮箱1766292701@qq.com
2023-09-19 22:03
caicaixiaoya

caicaixiaoya

回复 博弈or博野 :
请问这个问题解决了吗,急!
2023-09-19 22:01
2***@qq.com

2***@qq.com

大佬,求一份代码参考下
2022-10-21 15:17
成王败寇

成王败寇

我也需要,弄了一个导入本地图片加水印在保存到相册安卓10及以下都行升级安卓11后,结果跨域了 水平有限无法解决。求大佬分享一份参考学习。444300641@qq.com
2022-02-14 15:16
l***@163.com

l***@163.com

感谢大佬,真的是,今天改老版本项目出现的这个问题。
2021-06-25 19:24
刘星

刘星

安卓找到 大约是cropper.replace(dataBase);

改成一下代码 这里 base64tou就是穿过来的地址 安卓就不报错了

plus.io.resolveLocalFileSystemURL(base64tou, function(entry) {
entry.file(function(file) {
var fileReader = new plus.io.FileReader();
fileReader.onload = function(e) {};
fileReader.readAsDataURL(file);
fileReader.onloadend = function(e) {
let dataBase = e.target.result;
cropper.replace(dataBase);
}
}, function(e) {
plus.nativeUI.toast('读取文件失败,请稍后重试!')
});
});
2021-06-05 20:07
1***@163.com

1***@163.com

大佬,求份代码16619721346@163.com.拜托了
2021-05-05 16:51
1***@qq.com

1***@qq.com

大佬,求份代码1275107394@qq.com
2020-12-01 16:43
1***@163.com

1***@163.com

大佬,求份代码34809236@qq.com
2020-10-28 11:44
博弈or博野

博弈or博野

同理,谁有这个代码呀,我这两天在iOS上真机调试的时候,遇到的坑就是绕不过$image.cropper("getCroppedCanvas").toDataURL();这个,扎心呀。
2020-06-26 11:01