PHP生成二维码【endroid/qr-code 4.x】

发布于:2024-04-18 ⋅ 阅读:(197) ⋅ 点赞:(0)
1. 前言

packagist 传送门: endroid/qr-code - Packagist

使用该扩展前,先确认其 PHP 版本要求,endroid/qr-code 4.x 需要 PHP 版本 7.4+

使用前需要检查下是否启用了 gd2 扩展,对于 endroid/qr-code 版本选择,参考扩展包文档对 PHP 版本的要求

2. 安装扩展

执行 composer 命令安装 endroid/qr-code 扩展


  1. composer require endroid/qr-code

会生成如下目录结构内容


  1. ├─vendor
  2. │ ├─autoload.php
  3. │ ├─ ...
  4. ├─composer.json
  5. ├─composer.lock

如果当前项目架构没有基于任何框架,只需要引入 composer 的自动加载文件即可

如果当前项目是基于 ThinkPHP,Laravel 等主流框架,这些框架都支持 composer,执行安装扩展包命令后可以直接使用


  1. require 'vendor/autoload.php';
3. 生成二维码

使用 Builder 生成器:


  1. use Endroid\QrCode\Builder\Builder;
  2. use Endroid\QrCode\Encoding\Encoding;
  3. use Endroid\QrCode\ErrorCorrectionLevel\ErrorCorrectionLevelHigh;
  4. use Endroid\QrCode\Label\Alignment\LabelAlignmentCenter;
  5. use Endroid\QrCode\Label\Font\NotoSans;
  6. use Endroid\QrCode\RoundBlockSizeMode\RoundBlockSizeModeMargin;
  7. use Endroid\QrCode\Writer\PngWriter;
  8. $result = Builder::create()
  9. ->writer(new PngWriter())
  10. ->writerOptions([])
  11. // 二维码文本
  12. ->data('https://www.itqaq.com')
  13. // 内容编码
  14. ->encoding(new Encoding('UTF-8'))
  15. // 容错等级(越高二维码越密集)
  16. ->errorCorrectionLevel(new ErrorCorrectionLevelHigh())
  17. // 二维码内容区域大小
  18. ->size(300)
  19. // 二维码内容外边距大小
  20. ->margin(10)
  21. // 二维码内容圆形块尺寸模型
  22. ->roundBlockSizeMode(new RoundBlockSizeModeMargin())
  23. // 二维码中间区域logo图片
  24. ->logoPath(__DIR__ . '/3.png')
  25. ->logoResizeToWidth(100)
  26. ->logoResizeToHeight(100)
  27. // 二维码下方文字
  28. ->labelText('长按识别二维码')
  29. ->labelFont(new NotoSans(20))
  30. ->labelAlignment(new LabelAlignmentCenter())
  31. // 验证读取器(默认情况下禁用)
  32. ->validateResult(false)
  33. // 执行生成器
  34. ->build();

不使用 Builder 生成器:


  1. use Endroid\QrCode\Color\Color;
  2. use Endroid\QrCode\Encoding\Encoding;
  3. use Endroid\QrCode\ErrorCorrectionLevel\ErrorCorrectionLevelLow;
  4. use Endroid\QrCode\QrCode;
  5. use Endroid\QrCode\Label\Label;
  6. use Endroid\QrCode\Logo\Logo;
  7. use Endroid\QrCode\RoundBlockSizeMode\RoundBlockSizeModeMargin;
  8. use Endroid\QrCode\Writer\PngWriter;
  9. $writer = new PngWriter();
  10. $qrCode = QrCode::create('https://www.itqaq.com')
  11. // 内容编码
  12. ->setEncoding(new Encoding('UTF-8'))
  13. // 容错等级
  14. ->setErrorCorrectionLevel(new ErrorCorrectionLevelLow())
  15. // 内容区域大小
  16. ->setSize(300)
  17. // 内容区域外边距
  18. ->setMargin(10)
  19. // 内容圆形块尺寸模型
  20. ->setRoundBlockSizeMode(new RoundBlockSizeModeMargin())
  21. // 内容颜色
  22. ->setForegroundColor(new Color(0, 0, 0))
  23. // 背景颜色
  24. ->setBackgroundColor(new Color(255, 255, 255));
  25. // 二维码logo logo
  26. $logo = Logo::create(__DIR__ . '/3.png')
  27. ->setResizeToWidth(50);
  28. // 二维码下方文字 label
  29. $label = Label::create('Label')
  30. ->setTextColor(new Color(255, 0, 0));
  31. // 生成二维码数据对象(后面两个参数都是可选的)
  32. $result = $writer->write($qrCode, $logo, $label);

实际开发中,使用最多的是根据一串普通文本生成字符串,所以我将代码做了简化,方便以后快速使用


  1. use Endroid\QrCode\QrCode;
  2. use Endroid\QrCode\Writer\PngWriter;
  3. use Endroid\QrCode\Encoding\Encoding;
  4. $qrCode = QrCode::create('https://www.itqaq.com')
  5. // 内容编码
  6. ->setEncoding(new Encoding('UTF-8'))
  7. // 内容区域大小
  8. ->setSize(200)
  9. // 内容区域外边距
  10. ->setMargin(10);
  11. // 生成二维码数据对象
  12. $result = (new PngWriter)->write($qrCode);
4. 输出二维码

以下是三种输出二维码的方式,根据项目场景选择合适的方式即可


  1. // 直接输出在浏览器中
  2. // ob_end_clean(); //处理在TP框架中显示乱码问题
  3. // header('Content-Type: ' . $result->getMimeType());
  4. // echo $result->getString();
  5. // 将二维码图片保存到本地服务器
  6. // $result->saveToFile(__DIR__ . '/qrcode.png');
  7. // 返回 base64 格式的图片
  8. $dataUri = $result->getDataUri();
  9. echo "<img src='{$dataUri}'>";
  10. https://www.lengleng.net

网站公告

今日签到

点亮在社区的每一天
去签到