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

解决了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

要回复文章请先登录注册

小权

小权

是的,关键就是WKwebview下,本地图片需要先转成base64。但是据客户反馈,iOS10 依旧会有问题。不知道你们有遇到过吗
2020-06-23 17:16
黄马尼

黄马尼

回复 黄马尼 :
解决啦,这里我把代码分享一下
plus.io.resolveLocalFileSystemURL(path,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;
var img = document.getElementById("userImage_id");
img.src = dataBase;
if(window.imageDisable == true){
$("#userImage_id").cropper("enable");
}
$("#userImage_id").cropper("replace" , dataBase);
document.getElementById("userImage_id").onclick = function(){
plus.runtime.openFile(path);
}
}
},function(e){
mui.toast('打开文件失败');
});
},
2020-06-05 17:15
黄马尼

黄马尼

困扰这个问题很久了,麻烦大佬分享一下代码看看,343377274@qq.com,在此感激不尽!
2020-06-02 17:10
chenmba

chenmba

187085964@qq.com谢谢大佬!
2020-06-01 10:20
想得美

想得美

做成插件上传到市场吧
2020-05-28 14:23
1***@qq.com

1***@qq.com

1131895059@qq.com谢谢大佬!
2020-05-28 14:11
1***@qq.com

1***@qq.com

大佬,求份代码1323483895@qq.com
2020-05-21 17:16
4***@qq.com

4***@qq.com

回复 4***@qq.com :
解决啦,参考大佬的思路,我这边是需要用canvas进行图片压缩,但是toDataURL一直报跨域,我采取的方式是先把图片进行压缩,然后通过fileReader读取文件,最后转为base64就可以了
2020-04-29 11:37
4***@qq.com

4***@qq.com

大佬,可以求代码参考下吗,小白被这个问题困扰很久了T_T 邮箱416270230@qq.com
2020-04-29 10:58
男色经典

男色经典 (作者)

回复 路飞大王 :
已发
2020-04-21 16:47