使用PHP QR Code生成二维码

在现在的业务逻辑中,有时会遇到一些生成二维码的需求,
这是我们我们可以使用PHPqrCode一个PHP二维码生成类库,
利用它我们可以轻松的生成二维码。
官网:http://phpqrcode.sourceforge.net/
首先我们去官网下载这个类库,然后require或include进去,
我们使用phpqrcode.php就可以生成二维码了,
首先您的PHP环境必须开启支持GD2扩展。

案例一:

require_once('phpqrcode.php');
QRcode::png('https://fengkui.net/');

使用方法及参数含义:

png($text, $outfile = false, $level = QR_ECLEVEL_L, $size = 3, $margin = 4, $saveandprint=false)

第一个参数$text,就是上面代码里的URL网址参数,
第二个参数$outfile默认为否,不生成文件,只将二维码图片返回,否则需要给出存放生成二维码图片的路径
第三个参数$level默认为L,这个参数可传递的值分别是L(QR_ECLEVEL_L,7%),M(QR_ECLEVEL_M,15%),Q(QR_ECLEVEL_Q,25%),H(QR_ECLEVEL_H,30%)。这个参数控制二维码容错率,不同的参数表示二维码可被覆盖的区域百分比。利用二维维码的容错率,我们可以将头像放置在生成的二维码图片任何区域。
第四个参数$size,控制生成图片的大小,默认为4
第五个参数$margin,控制生成二维码的空白区域大小
第六个参数$saveandprint,保存二维码图片并显示出来,$outfile必须传递图片路径。

案例二(生成二维码文件):

require_once('./phpqrcode.php');
$text = 'https://fengkui.net/';
$outfile = 'qrcode.png'; // 生成图片路径及文件名
$level = QR_ECLEVEL_L; // 容错率
$size = 8; // 生成图片大小 :1到10
$margin = 2; // 边框大小
$saveandprint = false;
QRcode::png($text, $outfile, $level, $size, $margin, $saveandprint);

冯奎博客

案例三(生成带logo二维码):
接着案例二,准备好二维码图片和logo图片

$logo = 'logo.png'; // 准备好的logo图片
$QR = 'qrcode.png'; // 已经生成的原始二维码图
if ($logo !== FALSE) {
    $QR = imagecreatefromstring(file_get_contents($QR));
    $logo = imagecreatefromstring(file_get_contents($logo));
    $QR_width = imagesx($QR); // 二维码图片宽度
    $QR_height = imagesy($QR); // 二维码图片高度
    $logo_width = imagesx($logo); // logo图片宽度
    $logo_height = imagesy($logo); // logo图片高度
    $logo_qr_width = $QR_width / 5; // logo图片在二维码图片中宽度大小
    $scale = $logo_width/$logo_qr_width;
    $logo_qr_height = $logo_height/$scale; // logo图片在二维码图片中高度大小
    $from_width = ($QR_width - $logo_qr_width) / 2; //重新组合图片并调整大小
    imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width,
        $logo_qr_height, $logo_width, $logo_height);
}
// $filename = "qrcode_logo.png";
// imagepng($QR,$filename); // 保存最终生成的二维码到本地

//直接输出图片到浏览器
Header("Content-type: image/png");
ImagePng($QR);

exit();

冯奎博客

冯奎博客
请先登录后发表评论
  • 最新评论
  • 总共0条评论