婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 詳解canvas.toDataURL()報錯的解決方案全都在這了

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

熱門標簽:南昌仁和怎么申請開通400電話 平涼地圖標注位置怎么弄 只辦理400電話 機器人外呼系統存在哪些能力 如何獲取地圖標注客戶 電話機器人黑斑馬免費 高德地圖標注地點糾錯 拓展地圖標注 電話機器人電銷系統掙話費

報錯詳盡信息

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直接存儲或者生成一張圖片;
// 所以會用到 toDataURL
console.log(canvas.toDataURL('image/jpeg'))
return canvas;
}

栗子1

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

<div id="d1">
<img style="width: 300px;height: 240px;" src="http://jb51.net/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()報錯內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:池州 遼源 永州 新疆 漯河 棗莊 西藏 青島

巨人網絡通訊聲明:本文標題《詳解canvas.toDataURL()報錯的解決方案全都在這了》,本文關鍵詞  詳解,canvas.toDataURL,報,錯的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解canvas.toDataURL()報錯的解決方案全都在這了》相關的同類信息!
  • 本頁收集關于詳解canvas.toDataURL()報錯的解決方案全都在這了的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91精品国产综合久久久蜜臀粉嫩 | 中文字幕在线不卡一区| 99re这里只有精品视频首页| 麻豆久久久久久| 裸体健美xxxx欧美裸体表演| 夜夜嗨av一区二区三区| 中文字幕欧美国产| 久久婷婷色综合| 26uuu亚洲综合色| 久久久九九九九| 日韩精品自拍偷拍| 精品少妇一区二区三区免费观看| 日韩午夜电影av| 3751色影院一区二区三区| 91福利在线观看| 99精品欧美一区二区三区综合在线| 国内精品国产成人国产三级粉色| 日本免费在线视频不卡一不卡二 | 国产精品77777| 国产麻豆欧美日韩一区| 国产精品1024久久| eeuss鲁片一区二区三区| 99久久er热在这里只有精品15| 欧美性受极品xxxx喷水| 欧美综合一区二区三区| 欧美色男人天堂| 日韩精品一区二区三区在线播放 | 久久亚洲影视婷婷| 亚洲成人在线观看视频| 欧美xxxxxxxxx| 一区二区三区四区在线免费观看| 樱桃视频在线观看一区| 美日韩一区二区三区| 成人免费视频一区| 欧美女孩性生活视频| 国产精品视频在线看| 蜜乳av一区二区| 色偷偷成人一区二区三区91| 久久久久久久久97黄色工厂| 欧美私人免费视频| 日韩视频一区二区三区| 国产精品亚洲人在线观看| 激情综合网av| 日韩三级电影网址| 日本不卡一区二区| 久久综合久久综合久久| 亚洲女同女同女同女同女同69| 日本sm残虐另类| 成人涩涩免费视频| 91精品国产欧美一区二区成人| 久久网这里都是精品| 亚洲国产人成综合网站| 成人av电影在线播放| 日韩三级精品电影久久久| 亚洲精品高清在线| 岛国精品在线播放| 国产视频视频一区| 午夜精品在线视频一区| av动漫一区二区| 51精品秘密在线观看| 亚洲精品视频自拍| av午夜精品一区二区三区| 国产欧美日韩另类视频免费观看| 精品久久久久久久久久久久包黑料| 午夜精品爽啪视频| 91福利小视频| 午夜精品一区在线观看| 欧美美女一区二区在线观看| 亚洲va欧美va人人爽| 欧美一区二区日韩一区二区| 日本va欧美va瓶| 日韩你懂的在线播放| 精品国产免费视频| 日韩欧美一区二区不卡| 国产精品美女久久久久久久网站| 国产欧美一区二区三区在线看蜜臀| 欧美肥妇毛茸茸| 日韩精品一区二区三区视频播放 | 欧美日韩国产综合一区二区三区 | 久久电影国产免费久久电影 | 日韩欧美不卡一区| 91免费版在线| 成人性色生活片| 视频在线观看一区二区三区| 中文天堂在线一区| 久久久久久免费| 欧美一级xxx| 欧美丰满一区二区免费视频| 成人av片在线观看| 日本不卡不码高清免费观看| 亚洲成人综合视频| 亚洲一区二区三区四区中文字幕| 亚洲色图制服诱惑 | 欧美日韩国产综合一区二区| av在线一区二区| 成人黄色av电影| 狠狠色狠狠色综合系列| 久久精品噜噜噜成人av农村| 日本亚洲电影天堂| 日韩在线a电影| 丝袜亚洲另类欧美| 秋霞午夜av一区二区三区| 亚洲第一会所有码转帖| 一区二区三区四区亚洲| 国产精品久久久久久久久搜平片 | 欧美剧情片在线观看| 欧美日韩精品三区| 久久成人综合网| 国产在线精品一区二区夜色| 日韩国产精品久久久久久亚洲| 亚洲高清免费在线| 日韩专区欧美专区| 91精品国产综合久久福利| 色综合天天性综合| 欧美精品亚洲二区| 99久久婷婷国产精品综合| 日本亚洲电影天堂| 国产精品免费视频网站| 3atv一区二区三区| 久久综合一区二区| 一区二区三区日韩欧美精品| 欧美一区二区三级| 久久精品99国产国产精| 久久久亚洲午夜电影| 成人app网站| 精品久久国产字幕高潮| 本田岬高潮一区二区三区| 久久久久久亚洲综合影院红桃| 国产一区免费电影| 懂色av一区二区三区免费看| 国产精品视频在线看| 久久人人97超碰com| 日韩一区二区三| 7777精品伊人久久久大香线蕉经典版下载 | 国产精品久线观看视频| 久久婷婷久久一区二区三区| 亚洲精品在线电影| 久久综合视频网| 亚洲国产精品高清| 亚洲男人的天堂在线观看| 亚洲免费观看在线观看| 一区二区三区国产精华| 香蕉成人伊视频在线观看| 午夜视频一区二区| 婷婷亚洲久悠悠色悠在线播放| 亚洲综合成人在线视频| 一区二区三区蜜桃网| 一区二区三区日韩在线观看| 亚洲最新在线观看| 婷婷国产在线综合| 亚洲女厕所小便bbb| 一区二区三区波多野结衣在线观看 | av在线不卡免费看| 日韩欧美国产不卡| 亚洲精品欧美在线| 国产一区二区美女| 7777精品伊人久久久大香线蕉| 国产精品欧美极品| 蜜桃视频在线一区| 欧美日韩中文字幕一区| 亚洲国产精华液网站w| 蜜臀a∨国产成人精品| 在线免费观看日本一区| 国产亚洲视频系列| 国产亚洲成年网址在线观看| 日韩视频在线一区二区| 日本一区二区三区在线观看| 亚洲婷婷综合色高清在线| 日日夜夜精品视频天天综合网| 加勒比av一区二区| av电影在线观看一区| 欧美情侣在线播放| 国产日韩视频一区二区三区| 亚洲精品免费在线播放| 九九精品视频在线看| 99久久er热在这里只有精品15 | 亚洲美女一区二区三区| 亚洲成a人片在线观看中文| 日本少妇一区二区| 成人黄色免费短视频| 8x福利精品第一导航| 国产精品拍天天在线| 美腿丝袜亚洲三区| 在线亚洲一区观看| 国产亚洲女人久久久久毛片| 亚洲激情图片一区| 国产精品一线二线三线精华| 日本精品视频一区二区| 久久综合久久久久88| 亚洲一区二区在线播放相泽| 国产一区二区三区最好精华液| 欧美无乱码久久久免费午夜一区| 久久久91精品国产一区二区精品| 亚洲电影激情视频网站| 成人黄色777网| 久久久天堂av| 久久精品二区亚洲w码| 欧美精品免费视频| 亚洲欧美日韩在线播放| 精品一区二区三区日韩|