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

在iOS应用中遇到使用cropper裁切图片时toDataURL()报跨域错误,尝试设置img.crossOrigin无效。原因是WKWebView的跨域限制。通过对比分析,发现jquery photoclip插件的文件读取方式可避免此问题。最终解决方案是结合两者思路:调用相机拍照,使用FileReader将本地文件读取为Base64,再由cropper渲染到canvas进行裁切,成功解决跨域问题。
摘要由CSDN通过智能技术生成

@[TOC](toDataURL() 跨域解决方案)

那些说 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控件读取用户上传的文件信息,

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值