国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 開發 > 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()報錯內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产有码在线| 欧美日韩一区二区三区视视频| 欧美黑人乱大交ⅹxxxxx| 亚洲天堂视频在线观看免费| 永久免费av网站| 欧美亚洲另类在线观看| 成年黄网站在线观看免费| 久久一本精品| 国产黄色免费在线观看| 国产福利电影在线观看| 一本大道久久a久久精品| www.超级碰| 国产精品xxx电影| 色悠久久久久综合网小说| 国产乱精品一区二区三区| 国产精品视频一区二区免费不卡| 亚洲wwwwww| 91国内精品久久久久| 国产在线二区| 香蕉视频免费在线播放| 国产女主播在线| 九七电影韩国女主播在线观看| 天天操天天操天天色天天要| www.蜜桃av| 国产成免费视频| 最近中文字幕mv免费高清电影| 亚洲欧洲成人| 国产精品剧情一区二区三区 | av网址在线看| 91社区在线观看| 国产网站在线免费观看| 福利视频在线看| 九九视频九九热| 老司机在线视频二区| 日韩精品免费一区二区| 国产精品99爱免费视频| 国产麻豆一级片| 国产免费福利| 99视频在线观看地址| 狠狠综合久久久综合| 激情在线视频播放| 国产女王在线**视频 | av手机免费观看| 91桃色在线| 国产激情二区| 国产xxx在线| 国产精品国产国产aⅴ| 国产视频福利| 91高清国产| 一本大道久久精品| 浪潮av一区| 国产视频1区| 国产精品免费视频一区一| 中文字幕日本在线| 国产精品入口麻豆免费| 国产香蕉视频在线看| 国产三级av在线| 国产99re| jizz在线视频| 91福利在线免费| 在线久久视频| 久草福利资源在线视频| 国产精品入口麻豆免费| av丝袜在线| 中文字幕国产欧美| www.久草.com| 国产激情三区| 精品资源在线看| 在线亚洲精品自拍| 国产中文第一页| 国产精品国产三级国产试看| 在线观看国产福利视频| 国产无遮挡又黄又爽免费网站 | 在线观看av网站| 国产中文字幕在线视频| 国产精彩视频在线观看免费蜜芽| 樱花草在线观看www| 国产69精品久久久久孕妇国产69久久 | 91涩漫在线观看c| а√天堂www在线а√天堂视频| 五月综合激情在线| 九九热视频在线观看| 91亚洲精选| 国产一级黄色| 美女永久在线网站| 香蕉视频在线看| 国产成人无吗| 国产精品一区二区婷婷| 日本aⅴ写真网站免费| 在线观看视频污| 91中文在线| 中文字幕日本三级| 福利在线国产| 成人欧美精品久久久久影院| 国产激情二区| 国产人成在线观看| 国产精品一二三区视频| 狠狠干在线视频| 麻豆精品免费视频入口| 日本福利在线| 波多野结衣中文字幕久久| 日本久久网站| 久热免费视频| 国产美女一区视频| 久久久久国产精品嫩草影院| www.操.com| 激情在线视频播放| 激情亚洲综合网| 国产免费福利| 成年网在线观看免费观看网址| 九色在线网站| 国产免费黄网站| 国产精品麻豆一区二区三区 | 午夜免费视频在线国产| 福利视频在线看| 国产欧美日韩第一页| 国产激情视频一区二区| 在线国产一级| 天天爱天天色| 国产极品视频| av手机免费观看| 免费在线高清av| 国产网友自拍电影在线| 91在线视频免费看| 超碰97在线免费观看| 久久综合精品视频| 国产黄色免费网| 九九热在线观看视频| 国产偷激情在线| 一区二区三区免费视频网站| 二区三区中文字幕| 在线中文字幕视频| 国产一区在线视频观看| 精品推荐国产麻豆剧传媒| 精品乱码一区二区三四区视频| 国产精品黄页网站在线播放免费| 97在线超碰| 最近高清中文在线字幕在线观看| 国产国语**毛片高清视频| 午夜影院免费看| 国产高清视频免费最新在线| 黄色毛片在线观看| av片在线观看| 69视频在线| 午夜视频99| 国产乱码在线| 久久五月精品| 欧美艹逼视频| www在线播放| 在线免费国产视频| 国产午夜在线观看| 成人午夜无人区一区二区| 亚洲社区在线| 在线一二三区| 国产激情视频在线| 国产色在线观看| 五月伊人六月| 国产乱视频在线观看播放| 97国产视频| 精品久久亚洲一级α| 国产视频三区| 最近中文字幕mv2018在线高清| www网站在线观看| yjizz视频网站在线播放| 国产精品视频福利一区二区| 国产在线激情视频| 中文字幕日本在线观看| 午夜国产福利在线| 国产精品99999| 国产videos| 99久久免费精品国产免费| 国产成人精品久久一区二区小说| 国产素人视频在线观看| 国产成人夜间影院在线观看| 69国产精品| а√天堂8资源在线官网 | 国产麻豆综合视频在线观看| 久久精品视频观看| 国产剧情av在线| 国产成人亚洲精品播放器下载| 6699久久国产精品免费| 欧美精品se| 国产一级电影网| 亚洲欧洲成人| 国产一卡2卡3卡免费网站| 国产h色视频在线观看| h网站免费在线观看| 国产在线超碰| 伊人资源视频在线| 狠狠操视频网| 国产99re| 狠狠操天天操夜夜操| 国产羞羞视频在线播放| 国产精品久久在线| 热99在线观看| 国产成人精品自线拍| 美女国产在线| 先锋av资源网| 国产夫妻视频| 成年午夜在线|