小編給大家分享一下Canvas跨域脫坑的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
先來(lái)看下實(shí)現(xiàn)方法。
實(shí)現(xiàn)方法
目標(biāo)圖片一般是由 圖片 + 文本 構(gòu)成。無(wú)論是千奇百怪的大小圖片,還是變幻莫測(cè)的各式文本,都能用 canvas api drawImage 和 fillText 方法來(lái)完成。
基本流程如下:
1、獲取 canvas 上下文 -- ctx
const canvas = document.querySelector(selector) const ctx = canvas.getContext('2d')
2、繪圖
忽略圖片上的內(nèi)容,直接用 drawImage 將其畫(huà)到 canvas 畫(huà)布上即可。
const image = new Image() image.src = src image.onload = () => { ctx.save() // 這里我們采用以下參數(shù)調(diào)用 this.ctx.drawImage(image, dx, dy, dWidth, dHeight) this.ctx.restore() }
drawImage 有3種參數(shù)使用方式,具體用法可以查看MDN 文檔。
3、獲取圖像數(shù)據(jù)
調(diào)用 HTMLCanvasElement DOM 對(duì)象提供的 toBlob(), toDataURL() 或 getImageData() 方法,即可。
canvas.toBlob(blob => { // 你要的 blob }, mimeType, encoderOptions)
這里的 mimeType 默認(rèn)值為 image/png。encoderOptions 指定了圖片質(zhì)量,可用于壓縮,不過(guò)需要 mimeType 格式為 image/jpeg 或者 image/webp。
Canvas 跨域
正常情況下,如果需要將繪制好的圖像輸出,我們可以調(diào)用 canvas 的 toBlob(), toDataURL() 或 getImageData() 方法來(lái)獲取到圖像數(shù)據(jù)。然而,遇到圖片跨域的情況就有些尷尬了??赡芑貓?bào)如下錯(cuò)誤:
Failed to execute 'toBlob' on 'HTMLCanvasElement': Tainted canvases may not be exported.
或者
Access to image at 'https://your.image.src' from origin 'https://your.website' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
先來(lái)看看第2種情況。
Access-Control-Allow-Origin
如果你跨域使用某些圖片資源,并且該服務(wù)未正確響應(yīng) Access-Control-Allow-Origin 頭信息, 則會(huì)報(bào)出如下錯(cuò)誤信息:
Access to image at 'https://your.image.src' from origin 'https://your.website' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
說(shuō)明不允許跨域訪問(wèn),那么你可以試著讓后臺(tái)修改 Access-Control-Allow-Origin 的值為 * 或 your.website, 或者改用同域資源(考慮下?)。
接下來(lái),我們來(lái)解決第1種情況。
img.crossOrigin = 'Anonymous'
為避免未經(jīng)許可拉取遠(yuǎn)程網(wǎng)站信息而導(dǎo)致的用戶隱私泄露(如 GPS 等信息,具體可搜索 Exif),在調(diào)用 canvas 的 toBlob(), toDataURL() 或 getImageData() 會(huì)拋出安全錯(cuò)誤:
Failed to execute 'toBlob' on 'HTMLCanvasElement': Tainted canvases may not be exported.
如果你的圖片服務(wù)允許跨域使用(如果不允許,見(jiàn)上條),那么你該考慮下給 img 元素加上 crossOrigin 屬性,即:
const image = new Image() image.crossOrigin = 'Anonymous' image.src = src
以上是“Canvas跨域脫坑的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)頁(yè)名稱(chēng):Canvas跨域脫坑的示例分析-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://chinadenli.net/article38/ioepp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、標(biāo)簽優(yōu)化、品牌網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、小程序開(kāi)發(fā)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容