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

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

要回复文章请先登录注册

男色经典

男色经典 (作者)

回复 michaelsfuture :
已发
2020-04-21 16:47
michaelsfuture

michaelsfuture

406368272@qq.com谢谢大佬!
2020-04-21 11:23
路飞大王

路飞大王

1054425342@qq.com求代码
2020-04-21 10:14
jy15973

jy15973

大佬,同求代码参考下
2020-04-18 15:05
男色经典

男色经典 (作者)

回复 陈大大丶 :
已发送,引入的文件也发了,引用位置没改,你自己改一下就好,其它的文件MUI本身就有,看看就懂,把我自己的业务改成你的业务就行了,我就没删除了。
2020-04-17 19:07
男色经典

男色经典 (作者)

回复 s***@qq.com :
已发送,引入的文件也发了,引用位置没改,你自己改一下就好,其它的文件MUI本身就有,看看就懂,把我自己的业务改成你的业务就行了,我就没删除了。
2020-04-17 19:07
陈大大丶

陈大大丶

995805697@qq.com 谢谢了大佬
2020-04-17 11:22
陈大大丶

陈大大丶

我也需要,好不容易弄了一个和需求差不多的图片裁剪框,结果跨域了 差点直接原地爆炸
2020-04-17 11:20
s***@qq.com

s***@qq.com

回复 男色经典 :
shaoml@qq.com 我现在急需要,随便梳理一下给我就可以,谢谢
2020-04-17 09:06
男色经典

男色经典 (作者)

回复 s***@qq.com :
有代码,你要啊?留下邮箱,我有时间整理一下给你。
2020-04-16 22:01