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. 图片服务放在同一域名
  • 相关阅读:
    多表查询+多对多 三表连查+子查询
    几个重要的关键字where+group by +having +order by + limit
    拷贝表 *** 与******
    一对一关系的补充
    几种基本的约束和外键(一对一 多对多 多对一)级联关系
    创建表的完整语法 数字类型(整型 浮点型) 字符型 时间和日期类型 集合和枚举类型
    随记Litter note
    视图 触发器 事务(重要) 存储过程 内置函数 流程控制 索引
    luogu P2774 方格取数问题
    luogu P4014 分配问题
  • 原文地址:https://www.cnblogs.com/fanlinqiang/p/11228080.html
Copyright © 2011-2022 走看看