zoukankan      html  css  js  c++  java
  • js生成带log的二维码(qrcodejs)

    github: qrcodejs

    cdn: http://static.runoob.com/assets/qrcode/qrcode.min.js

    #qrcode
    
    #qrcode
    	margin: 20px
    
    // 生成二维码图片
    let tmp = document.createElement('div');
    let qrcode = new QRCode(tmp, {
       text: "https://cn.vuejs.org/v2/guide/",
        128,
       height: 128,
       colorDark : "#000000",
       colorLight : "#ffffff",
       useCanvas: true,
       correctLevel : QRCode.CorrectLevel.H
    });
    // 加载logo
    let logo = new Image();
    //logo.crossOrigin = 'Anonymous';
    //logl.src = 'https://cn.vuejs.org/images/logo.png';
    logo.src = '';
    
    logo.onload = function () {
       let container = document.getElementById('qrcode');
       let qrImg = qrcode._el.getElementsByTagName('img')[0];
       let canvas = qrcode._el.getElementsByTagName('canvas')[0];
       var ctx = canvas.getContext("2d");
       ctx.drawImage(logo, 128 * 0.5 - 20, 128 * 0.5 - 20, 40, 40);
       qrImg.src = canvas.toDataURL();
       container.appendChild(qrcode._el);
       // 销毁临时dom
       tmp = null;
       qrcode = null;
       logo = null;
    }
    

    Canvas画图加载远程图片报错

    pen.js:26 Uncaught DOMException: Failed to execute 'toDataURL' on 'HTMLCanvasElement': Tainted canvases may not be exported.
           at Image.logo.onload (pen.js:33:22)
    

    没有跨域CORS授权也可以在 canvas 中使用图像, 但这样做就会污染(taints)画布。 只要 canvas 被污染, 就不能再从画布中提取数据, 也就是说不能再调用 toBlob(), toDataURL() 和 getImageData() 等方法, 否则会抛出安全错误(security error).
    这实际上是为了保护用户的个人信息,避免未经许可就从远程web站点加载用户的图像信息,造成隐私泄漏。

    解决方案:

    1. 允许远程服务器Access-Control-Allow-Origin开启跨域
    2. 图片服务放在同一域名
  • 相关阅读:
    第十二周助教总结
    第十一周助教总结
    记一次数据库mysql与tidb查询时的区别
    括号校验-Java
    (四)栈和队列的应用
    (三)栈和队列的链式存储结构
    (二)栈和队列的顺序存储结构
    windows开放服务可以远程和被访问(两台电脑可以互相访问)
    (一)栈和队列的基本概念
    (一)数据结构基本概念、存储结构、复杂度
  • 原文地址:https://www.cnblogs.com/fanlinqiang/p/11228080.html
Copyright © 2011-2022 走看看