欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

怎么解決canvas繪圖時遇到的跨域問題

這篇文章主要介紹了怎么解決canvas繪圖時遇到的跨域問題,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)自2013年起,公司以網站設計、網站制作、系統(tǒng)開發(fā)、網絡推廣、文化傳媒、企業(yè)宣傳、平面廣告設計等為主要業(yè)務,適用行業(yè)近百種。服務企業(yè)客戶超過千家,涉及國內多個省份客戶。擁有多年網站建設開發(fā)經驗。為企業(yè)提供專業(yè)的網站建設、創(chuàng)意設計、宣傳推廣等服務。 通過專業(yè)的設計、獨特的風格,為不同客戶提供各種風格的特色服務。

當在canvas中繪制一張外鏈圖片時,我們會遇到一個跨域問題。

示例如下:

<!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" alt="">
    <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>

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

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

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

這是一個苦惱的問題,但幸運的是img新增了crossorigin屬性,這個屬性決定了圖片獲取過程中是否開啟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" alt="">
    <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');

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

感謝你能夠認真閱讀完這篇文章,希望小編分享怎么解決canvas繪圖時遇到的跨域問題內容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細的解決方法等著你來學習!

本文題目:怎么解決canvas繪圖時遇到的跨域問題
標題來源:http://aaarwkj.com/article48/jpdohp.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供微信小程序、外貿建站、響應式網站、外貿網站建設、定制網站、服務器托管

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網站建設
亚洲美女香蕉视频在线| 久久99久久精品视频国产| 亚洲国产精品午夜福利在线播放| 久久热福利视频就在这里| 亚洲精品紧身裙女教师av| 国产精品黄色片在线观看| 日本一区二区三区免费不卡视频| 一区二区三区乱码国产在线| 亚洲国产精品视频自拍| 国产黄色大片一级久久| 欧美性极品少妇精品网站| 久久精品高潮999久久久| 国产精品九九久久精品女同| 欧美日本国产老熟女视频| 色人阁在线精品免费视频| 日韩av在线观看大全| 国产av剧情极品丝袜美女| 亚洲综合成人av在线| 国产,欧美,日韩,日日骚| 久久精品国产视频在热| 日本成人精品一区二区三区| 日本理论午夜三级在线观看| 国产黄色一区二区三区| 国产精品国产三级国av中文| 免费国产午夜福利在线| 国产免费成人午夜免费视频| 国产九色91中文在线视频| 亚洲视频在线视频看视频在线| 西西美女掰开阴让你看| 日本精品一区二区不卡| 中文字幕人妻久久精品一区| 色中文字幕人妻诱惑制服| 92午夜福利在线视频| 国产精品18禁一区二区三区| 欧美日韩69av网| 肉肉开房天天操夜夜操| 中文字幕乱码人妻一区二| 开裆丝袜高跟啪啪高潮av| 男女午夜激情啪啪视频| 丰满少妇被激烈的插进去| 精品久久久久久亚洲野狼|