zoukankan      html  css  js  c++  java
  • 二维码生成插件qrious及网站扫码登录的一些理解

    什么是二维码

    ​  二维码又称QR Code,QR全称Quick Response,是一个近几年来移动设备上超流行的一种编码方式,它比传统的Bar Code条形码能存更多的信息,也能表示更多的数据类型。

    ​  二维条码/二维码(2-dimensional bar code)是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的;在代码编制上巧妙地利用构成计算机内部逻辑基础的“0”、“1”比特流的概念,使用若干个与二进制相对应的几何形体来表示文字数值信息,通过图象输入设备或光电扫描设备自动识读以实现信息自动处理:它具有条码技术的一些共性:每种码制有其特定的字符集;每个字符占有一定的宽度;具有一定的校验功能等。同时还具有对不同行的信息自动识别功能、及处理图形旋转变化点。

    特点:

    信息容量大, 可以容纳多达1850个大写字母或2710个数字或500多个汉字
    应用范围广, 支持文字,声音,图片,指纹等等...
    容错能力强, 即使图片出现部分破损也能使用
    成本低, 容易制作

    容错级别:

    ​ **L级**(低) 7%的码字可以被恢复。
    ​ **M级**(中) 的码字的15%可以被恢复。
    ​ **Q级**(四分)的码字的25%可以被恢复。
    ​ **H级**(高) 的码字的30%可以被恢复。

    二维码生成插件qrious.js

      qrious是一款基于HTML5 Canvas的纯JS二维码生成插件。通过qrious.js可以快速生成各种二维码,你可以控制二维码的尺寸颜色,还可以将生成的二维码进行Base64编码。

    参数类型默认值描述
    background String "white" 二维码的背景颜色。
    foreground String "black" 二维码的前景颜色。
    level String "L" 二维码的误差校正级别(L, M, Q, H)。
    mime String "image/png" 二维码输出为图片时的MIME类型。
    size Number 100 二维码的尺寸,单位像素。
    value String "" 需要编码为二维码的值

    qrious生成二维码的代码:

    <html>
        <head>
            <title>二维码入门小demo</title>
        </head>
        <body>
            <img id="qrious">
            <script src="qrious.min.js"></script>
            <script>
                var qr = new QRious({
                    element:document.getElementById('qrious'),
                    size:250,        
    level:
    'H',
    value:
    'http://www.baidu.com' }); </script> </body> </html>

    网站扫码登录的一些理解:

    第一步:用户A访问网页版系统点击使用二维码登录,系统服务器为这个会话生成一个全局唯一的id,并以此id为基础生成url做成二维码放到页面上(www.xxx.com/login.html?id=xxxxxxx),
    于此同时需要把此id写到redis之类的数据库中(可以以id为key),此时系统并不知道访问者是谁。 第二步:用户A打开自己的该系统的手机APP并扫描这个二维码,首先验证手机端用户是否登录,登录过后跳转到扫码得到的url中。 第三步:手机端是登录状态,用户点击url中的确认登录后,手机上的客户端将账号信息和这个扫描得到的id 一起提交到redis中(根据id这个key,把用户信息及token之类的登录信息写到value中)。 第四步:一般来说在第一步之后,需要建立一个长连接或者轮询查看redis这个以id为key的value值,如果value不为空且验证用户身份后,通知网页版系统,这个ID对应的用户是A,然后使其登录网页版。 但是这种长连接是比较耗费资源的,可以考虑用GOEASY之类的web消息推送来代替长连接这种方式。
  • 相关阅读:
    MySQL数据表类型 = 存储引擎类型
    删除链表节点
    链表逆序(反转)
    腾讯2012笔试题
    MysqL数据表类型
    进程间的通信方式
    网络套接字编程学习笔记一
    HTTP报头
    C语言排序算法
    交换排序经典的冒泡排序算法总结
  • 原文地址:https://www.cnblogs.com/blazeZzz/p/9606218.html
Copyright © 2011-2022 走看看