Canvas - 错误:Tainted canvases may not be exported

记录日期:2019年6月26日 22点21分

 

Canvas 的内容保存为图片,但是一直不成功。报错信息如标题,意思指被污染的画布不能被导出。

理论上来讲,导出为图片是一定可行的,但是被污染的画布是不允许被导出的。

问题就在于,什么叫被污染的画布。

找到官网说明,参考链接:https://developer.mozilla.org/en-US/docs/Web/HTML/CORS_enabled_image

image

图上划线的部分,为什么要增加这样的限制,并且说明从其他地方(未经允许跨域的源)获取的数据加入画布内容。下面列举了,如从img和svg元素获得的内容是不允许的,因为这两个元素允许使用外部图片(来源不明),涉及跨域了,所以从这两个元素导入过内容的画布,是不能被导出的。

 

项目中,在画布准备的时候,从img导入了一个准备的图片,于是画布被污染了,后面完成时需要导入时,就报错 “Tainted canvases may not be exported”。

解决方案:不从img导入内容,结果可以正常导出。

转载于:https://www.cnblogs.com/Currention/p/11094339.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported"是一个报错信息,意味着当使用canvas的toDataURL()方法时,画布上存在被污染的图像(即跨域的图像),不能导出。原因是在使用drawImage()方法将跨域的图片绘制到canvas上。解决方法包括以下两个步骤: 1. 在引用图片之前设置跨域资源允许权限。这可以通过在创建image对象之后设置image对象的crossOrigin属性为'anonymous'来实现。示例代码如下: ``` var img = new Image(); img.setAttribute('crossOrigin', 'anonymous'); img.src = '图片地址'; ``` 请确保在设置crossOrigin属性之后再设置图片的src属性。 2. 确保存放图片的服务器开启了跨域允许权限。否则,可能会出现"No 'Access-Control-Allow-Origin' header is present on the requested resource"的错误提示。你可以联系服务器管理员或者在服务器端配置相应的跨域请求头。 通过以上两个步骤,你应该能够解决"Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported"的问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported [已解决]....](https://blog.csdn.net/qq_35516360/article/details/122065183)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Canvas引入跨域的图片导致toDataURL()报错的问题的解决](https://download.csdn.net/download/weixin_38693419/14830620)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [canvas生成图片toDataURL报错(Uncaught DOMException: Failed to execute ‘toDataURL‘ on ‘HTMLCanvasEl...](https://blog.csdn.net/sumimg/article/details/115375085)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值