@[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控件读取用户上传的文件信息,然后再转成base64进行处理。
我想想算了,就用photoclip吧,能用就行,结果发现这破东西根本不能用,缩方功能做的和shi一样,根本不行,跳来跳去,抖来抖去的,而且要先点击input选择文件才行,用户体验非常不好。
于是我想到了一个解决方案:
为什么不用photoclip 读取文件的思路来解决cropper的跨域问题呢?各取所长。
于是想着怎么把一个本地图径的path地址转换成file控件里的文件内容,而且要直接调用相机,而不是文件选择框。
最后形成一个完美的解决方案:
Ste