国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

詳解canvas繪圖時(shí)遇到的跨域問題

2024-08-26 00:20:34
字體:
供稿:網(wǎng)友

當(dāng)在canvas中繪制一張外鏈圖片時(shí),我們會遇到一個(gè)跨域問題。

示例如下:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>crossorigin</title></head><body>    <canvas width="600" height="300" id="canvas"></canvas>    <img id="image"    <script>        var canvas = document.getElementById('canvas');        var ctx = canvas.getContext('2d');        var image = new Image();        image.onload = function() {            ctx.drawImage(image, 0, 0);            document.getElementById('image').src = canvas.toDataURL('image/png');        };        image.src = 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3497300994,2503543630&fm=27&gp=0.jpg';    </script></body>

當(dāng)在瀏覽器中打開這個(gè)頁面時(shí),你會發(fā)現(xiàn)這個(gè)問題:

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

這是受限于 CORS 策略,會存在跨域問題,雖然可以使用圖像,但是繪制到畫布上會污染畫布,一旦一個(gè)畫布被污染,就無法提取畫布的數(shù)據(jù),比如無法使用使用畫布toBlob(),toDataURL(),或getImageData()方法;當(dāng)使用這些方法的時(shí)候 會拋出上面的安全錯(cuò)誤

這是一個(gè)苦惱的問題,但幸運(yùn)的是img新增了crossorigin屬性,這個(gè)屬性決定了圖片獲取過程中是否開啟CORS功能:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>crossorigin</title></head><body>    <canvas width="600" height="300" id="canvas"></canvas>    <img id="image"    <script>        var canvas = document.getElementById('canvas');        var ctx = canvas.getContext('2d');        var image = new Image();        image.setAttribute('crossorigin', 'anonymous');        image.onload = function() {            ctx.drawImage(image, 0, 0);            document.getElementById('image').src = canvas.toDataURL('image/png');        };        image.src = 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3497300994,2503543630&fm=27&gp=0.jpg';    </script></body>

對比上面兩段JS代碼,你會發(fā)現(xiàn)多了這一行:

image.setAttribute('crossorigin', 'anonymous');

就是這么簡單,完美的解決了!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識閱讀請移步到HTML教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 林州市| 民和| 西林县| 廉江市| 清涧县| 辽阳市| 遂宁市| 望江县| 昌都县| 莱州市| 简阳市| 天津市| 伊金霍洛旗| 仁怀市| 措美县| 施甸县| 莲花县| 河南省| 高邮市| 河西区| 会东县| 安化县| 潞城市| 开阳县| 定陶县| 新营市| 喀喇沁旗| 杂多县| 平塘县| 嵊泗县| 临武县| 越西县| 微博| 灵寿县| 伽师县| 礼泉县| 宣化县| 洞口县| 佛山市| 长白| 闽侯县|