image.png

二维码,就是为了承载一些数据的

  • 矩阵点
    • 通常是白色或黑色小点
    • 深色表示1
    • 白色表示0
  • 位置探测组
    • 三个位于角落的嵌套矩形
    • 用于定位二维码的方向
  • version
    • 1-40的数字
    • 数字越大,表示二维码的矩阵越大,不是像素点是矩阵点
      • 1 是 21*21
      • 40 是 177*177
  • mode 字符串编码方式
    • Numeric: 只编码数字
    • Alphanumeric: 数字和大写字母
    • Kanji: 日文和中文
    • Byte: 类似ascll

下图展示了不同字母编码格式,承载的字符数量,纠错等级越高,字符数量越少

Mode L M Q H
Numeric 7089 5596 3993 3057
Alphanumeric 4296 3391 2420 1852
Byte 2953 2331 1663 1273
Kanji 1817 1435 1024 784
  • 纠错等级,纠错等级越高,字符数量越少(这就是有些二维码模糊不清,你还能扫出来的原因)
    • L
    • M
    • Q
    • H

qrcode 服务端生成

  1. 生成一个文件 ```json const QRCode = require(‘qrcode’); QRCode.toFile(‘./public/qrcode/qrcode.png’, ‘https://www.yuque.com/zhanggaorui-webs‘, err => { console.log(err) })
  1. - 第一个参数是二维码保存的地址
  2. - 第二个参数二维码承载的内容,
  3. - 第三个参数二维码生成错误时的回调函数
  4. 2. 生成一个url
  5. ```json
  6. const QRCode = require('qrcode');
  7. QRCode.toDataURL('https://www.yuque.com/zhanggaorui-webs', (err, url) => {
  8. if (err) {
  9. console.log(err)
  10. }
  11. if (url) {
  12. console.log(url)
  13. }
  14. })

返回的数据是一个base64编码过得二维码图片url

  1. 

其他配置参数,详见官网https://github.com/soldair/node-qrcode

客户端生成 qrcodejs

官网: https://github.com/davidshimjs/qrcodejs

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  6. <title>Document</title>
  7. </head>
  8. <body>
  9. <div id="divcode"></div>
  10. <script src="https://cdn.bootcdn.net/ajax/libs/qrcodejs/1.0.0/qrcode.js"></script>
  11. <script>
  12. new QRCode(divcode, {
  13. text: "http://yuanjin.tech",
  14. width: 128,
  15. height: 128,
  16. colorDark: "blue",
  17. colorLight: "#fff",
  18. correctLevel: QRCode.CorrectLevel.H,
  19. });
  20. </script>
  21. </body>
  22. </html>

详细配置见官网