亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

詳解canvas.toDataURL()報錯的解決方案全都在這了

2024-09-05 07:23:21
字體:
來源:轉載
供稿:網友

報錯詳盡信息

Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.

關鍵詞

  • canvas.toDataURL()
  • crossOrigin
  • Access-Control-Allow-Origin

前言

最近在做一個創意類的圖片合成工具,大概齊就是通過拼接自定義的文字和圖片信息生成一張商品圖片類似的功能,項目中用到了fabric.js這個畫板庫,最后一步在保存圖片的時候報上面的一長串錯誤,墻內墻外搜了一遍,給出的解決方案都不全面,為避免同學們再次踩坑,于是有了此文

正文

我們在convertDOM2Image時,如果DOM內存在圖片資源,該資源所在的web-server是不支持跨域的,保存圖片是不會成功的。

因此在排查問題時,首先要確定

  • web-server是否允許跨域,我們以nginx為例,response-header內要存在Access-Control-Allow-Orgin:xxxx(可以是*,安全性要求比較高的可以根據主域名自定義)
  • 如果是img標簽, 是否添加了crossorigin="anonymous", 如果是Image對象,同樣是否添加了改屬性obj.crossOrigin='anonymous'
  • 如果還不行,這里先不把答案放出來,我們先看看栗子

在接下來的栗子中我們會用到將Image轉換為canvas對象的方法

function convertImageToCanvas(image) {// 創建canvas DOM元素,并設置其寬高和圖片一樣 let canvas = document.createElement("canvas");canvas.width = image.width;canvas.height = image.height;canvas.getContext("2d").drawImage(image, 0, 0);// 我們在實際的開發中,需要將抓換后的base64圖片編碼傳輸到后臺圖片服務器,由server直接存儲或者生成一張圖片;// 所以會用到 toDataURLconsole.log(canvas.toDataURL('image/jpeg'))return canvas;}

栗子1

本地未設置跨域允許選項crossorigin=anonymous,web-server未設置跨域允許選項

<div id="d1"><img style="width: 300px;height: 240px;" src="http://VeVb.com/images/cover_thumbnail_3rd.jpg" alt=""><p>本地未設置跨域允許選項crossorigin=anonymous,web-server未設置跨域允許選項</p></div><button onclick="setCanvas('d1')">canvas保存</button>
function setCanvas(DOMID) {let img = document.getElementById(DOMID).querySelector('img')document.body.appendChild(convertImageToCanvas(img))}

很顯然,報錯

栗子2

本地標簽內設置跨域允許選項, web-server未設置跨域允許選項

這次連圖片都出不來,直接報錯

這個好理解,瀏覽器同源策略限制嘛

Access to image at 'xxxx' (redirected from 'xxxx') from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

栗子3

本地未設置跨域允許選項crossorigin=anonymous, web-server設置跨域允許選項

報錯,妥妥的。

栗子4

本地標簽內設置跨域允許選項crossorigin=anonymous, web-server設置跨域允許選項

<div id="d4"><img style="width: 300px;height: 240px;" src="https://img.alicdn.com/tfs/TB1_uT8a5ERMeJjSspiXXbZLFXa-143-59.png" alt="" crossorigin="anonymous"><p>本地設置跨域允許選項`crossorigin=anonymous`,`web-server`設置跨域允許選項</p></div><button onclick="setCanvas('d4')">canvas保存</button>

居然可以了,但是~如果在代碼內設置跨域呢?

栗子5

function setCanvas(DOMID) {let img = document.getElementById(DOMID).querySelector('img')img.crossOrigin= 'anonymous'document.body.appendChild(convertImageToCanvas(img))}

報錯

我看官方文檔的意思是必須同步設置crossOrigin=anonymous,該圖片憑證才會被信任

This means that CORS is enabled and credentials are sent if the image is fetched from the same origin from which the document was loaded.

否則緩存的圖像數據仍然會被畫布視為有污染的跨源內容.

怎么辦?重新取一遍圖片唄,加個隨機數,圖片還是那個圖片,不過加了個馬甲,瀏覽器就不認識了

栗子6

function setCanvas(DOMID) {let img = document.getElementById(DOMID).querySelector('img')img.src =img.src+'?v='+Math.random()img.crossOrigin= 'anonymous'img.onload=()=>{document.body.appendChild(convertImageToCanvas(img))}}

binggo, 完美解決

所以我們在開發過程中,新建圖片,更換圖片,還原圖片等功能代碼內,最好每一次都加個隨機數,以保證源都是最新的,不走緩存

多說一點吧,關于fabric.js的相關跨域配置見下方

let _fabricConfig = {// ....crossOrigin:'anonymous'};/* fabric對象 */let _fabricObj = new fabric.Canvas(id, _fabricConfig);// 新建圖片對象時let imgInstance = new fabric.Image.fromURL(url + '?v='+ Math.random(), img => {}, {crossOrigin: 'anonymous'})// 動態更新圖片時let currentActive = _fabricInstance.getActiveObj();currentActive.setSrc(randomURL, img =>{}, {crossOrigin: 'anonymous'})

github:http://github.com/phillyx

到此這篇關于詳解canvas.toDataURL()報錯的解決方案全都在這了的文章就介紹到這了,更多相關canvas.toDataURL()報錯內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
狠狠躁夜夜躁人人爽超碰91| 国产精品日日摸夜夜添夜夜av| 国产亚洲精品久久久久久牛牛| 久久久精品免费| 国产狼人综合免费视频| 国产伊人精品在线| 国产在线精品播放| 97视频在线观看视频免费视频| 国产精品久久久久久久电影| 欧美主播福利视频| 精品一区二区三区电影| 欧美美最猛性xxxxxx| 欧美精品999| 亚洲成人激情在线观看| 色多多国产成人永久免费网站| 久久影院模特热| 国产日韩欧美电影在线观看| 神马久久桃色视频| 亚洲色图偷窥自拍| 久久理论片午夜琪琪电影网| xxx成人少妇69| 欧美成年人视频网站欧美| 精品国产91乱高清在线观看| 亚洲色图狂野欧美| 一区二区av在线| 久久久亚洲影院你懂的| 亚洲人午夜精品| 精品亚洲一区二区三区四区五区| 亚洲男人的天堂在线| 欧美日韩日本国产| 亚洲欧洲午夜一线一品| 国产精品普通话| 国产成人高清激情视频在线观看| 亚洲精品成人网| 国产精品99久久久久久久久| 亚洲一区二区三区777| 久久天堂电影网| 久久天天躁日日躁| 国产成人精彩在线视频九色| 久久精品影视伊人网| 久久综合色88| 2018中文字幕一区二区三区| 成人h视频在线观看播放| 国产精品日韩欧美大师| 中文字幕欧美专区| 91日韩在线视频| 欧美大片在线影院| 亚洲r级在线观看| 亚洲国产美女精品久久久久∴| 国产精品视频自拍| 在线激情影院一区| 欧美精品video| 欧美日韩国产中文精品字幕自在自线| 久久久久久国产精品久久| 成人免费激情视频| 亚洲国产91色在线| 欧美午夜视频在线观看| 久久久中精品2020中文| 91精品国产乱码久久久久久蜜臀| 国产69精品久久久久9| 日本亚洲欧美三级| 最新中文字幕亚洲| 国产精品18久久久久久首页狼| 久久久久久噜噜噜久久久精品| 国产一区二区三区视频在线观看| 亚洲老板91色精品久久| 欧美极品在线视频| 日韩电影中文字幕av| 伊人青青综合网站| 久久国产一区二区三区| 一本色道久久88综合日韩精品| 97国产精品视频人人做人人爱| 成人免费福利视频| 98午夜经典影视| 日韩欧美视频一区二区三区| 欧美激情国产日韩精品一区18| 日韩av影院在线观看| 亚洲v日韩v综合v精品v| 九九热r在线视频精品| 久久影院资源网| 亚洲国产成人在线播放| 欧美激情一区二区三区久久久| 久久成人亚洲精品| 亚洲天堂免费视频| 亚洲xxxxx| 欧美日韩一区二区在线| 欧美人成在线视频| 久久久国产精品视频| 欧美在线视频导航| 欧美电影免费观看高清完整| 亚洲一区二区三区sesese| 亚洲欧美999| 疯狂蹂躏欧美一区二区精品| 国产一区二区三区在线看| 国产精品视频永久免费播放| 欧美黑人一级爽快片淫片高清| 亚洲视频免费一区| 国产一区二区三区直播精品电影| 91福利视频在线观看| 久久九九亚洲综合| 久久免费福利视频| 国产精品自在线| 91免费的视频在线播放| www.欧美三级电影.com| 国产精品av免费在线观看| 精品国产乱码久久久久久天美| 大量国产精品视频| 国产成人精品优优av| 日韩精品免费电影| 欧美国产日本在线| 欧美高跟鞋交xxxxxhd| 中文字幕精品一区久久久久| 日韩中文字幕免费看| 亚洲va国产va天堂va久久| 亚洲综合成人婷婷小说| 久久久久久香蕉网| 久久久久久久电影一区| 欧美专区在线视频| 日本a级片电影一区二区| 午夜精品久久久久久久白皮肤| 国产精品九九久久久久久久| 国产精品视频999| 精品欧美一区二区三区| 亚洲一区二区免费| 欧美国产高跟鞋裸体秀xxxhd| 国产精品丝袜白浆摸在线| 亚洲大胆人体在线| 久久久久久久久久国产| 亚洲在线一区二区| 日本91av在线播放| 久久艳片www.17c.com| 欧美激情久久久| 国产中文字幕91| 成人写真视频福利网| 国产精品精品视频一区二区三区| 91免费看片网站| 日韩免费高清在线观看| 亚洲激情在线观看视频免费| 欧美日韩国产精品一区二区三区四区| 91九色视频导航| 久热国产精品视频| 色爱精品视频一区| 欧美专区中文字幕| 亚洲a级在线播放观看| 欧美精品18videos性欧美| 亚洲xxx视频| 亚洲国产成人精品电影| 国模私拍一区二区三区| 538国产精品一区二区在线| 疯狂蹂躏欧美一区二区精品| 国产网站欧美日韩免费精品在线观看| 亚洲午夜精品久久久久久久久久久久| 国产成人免费av电影| 欧美性猛交xxxx免费看漫画| 国产综合在线看| 欧美极品在线播放| 欧美老妇交乱视频| 91免费观看网站| 最近中文字幕mv在线一区二区三区四区| 中国日韩欧美久久久久久久久| 日韩中文第一页| 97国产真实伦对白精彩视频8| 欧美精品18videos性欧美| 91成人在线观看国产|