主页 > 知识库 > canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法

canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法

热门标签:地图标注软件打印出来 恶搞电话机器人 如何查看地图标注 电话机器人技术 ok电销机器人 黄石ai电销机器人呼叫中心 高德地图标注商户怎么标 智能电销机器人被禁用了么 欣鼎电销机器人 效果

我们要绘制一张图片,内容包括一张背景图和一个动态生成的二维码,前提是背景图是项目本身的静态资源,二维码是服务端动态生成的,二者不在同一域名下。

解决办法:把所有图片都重定向同一个域名下:

let count = 0;
let bgImg = document.creatElement('img');
let qrImg = document.creatElement('img');
bgImg.src = redirectUrl('x.png');
qrImg.src = redirectUrl('y.png');
[bgImg, qrImg].forEach((e) => {
    e.onload = () => {
        count ++;
        if (count === 2) {
            drawerImg(bgImg, qrImg);  
        }
    }
})
function redirectUrl (url) {
    return 'https://xxx/view?fileUrl=' + encodeURIComponent(url);
}
function drawerImg (imgContent, qrContent, scaleBy = 2) {
    let {bgImgW, bgImgH} = {375, 800};
    let {qrx, qry, qrw, qrh} = {20, 700, 50, 50};
    let Canvas = document.createElement('canvas');
    let ctx = Canvas.getContext("2d");
    Canvas.width = bgImgW * scaleBy;
    Canvas.height= bgImgH * scaleBy;
    ctx.drawImage(imgContent, 0, 0, bgImgW * scaleBy, bgImgH * scaleBy);
    ctx.drawImage(qrContent, qrx * scaleBy, qry * scaleBy, qrw * scaleBy, qrh * scaleBy);
    
    let nodeI = document.createElement("img");
    nodeI.src = Canvas.toDataURL();
    document.body.appendChild(nodeI)
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

标签:金昌 绥化 萍乡 赤峰 阿坝 聊城 中山 盘锦

巨人网络通讯声明:本文标题《canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法》,本文关键词  canvas,因为,图片资源,不在,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法》相关的同类信息!
  • 本页收集关于canvas因为图片资源不在同一域名下而导致的跨域污染画布的解决办法的相关信息资讯供网民参考!
  • 推荐文章