使用PHP生成二维码的两种方法(带logo图像)


Posted in PHP onMarch 14, 2014

一、利用Google API生成二维码
 Google提供了较为完善的二维码生成接口,调用API接口很简单,以下是调用代码:

$urlToEncode="https://3water.com"; 
generateQRfromGoogle($urlToEncode); 
/** 
 * google api 二维码生成【QRcode可以存储最多4296个字母数字类型的任意文本,具体可以查看二维码数据格式】 
 * @param string $chl 二维码包含的信息,可以是数字、字符、二进制信息、汉字。 
 不能混合数据类型,数据必须经过UTF-8 URL-encoded 
 * @param int $widhtHeight 生成二维码的尺寸设置 
 * @param string $EC_level 可选纠错级别,QR码支持四个等级纠错,用来恢复丢失的、读错的、模糊的、数据。 
 * L-默认:可以识别已损失的7%的数据 
 * M-可以识别已损失15%的数据 
 * Q-可以识别已损失25%的数据 
 * H-可以识别已损失30%的数据 
 * @param int $margin 生成的二维码离图片边框的距离 
 */ 
function generateQRfromGoogle($chl,$widhtHeight ='150',$EC_level='L',$margin='0') 
{ 
 $chl = urlencode($chl); 
 echo '<img src="http://chart.apis.google.com/chart?chs='.$widhtHeight.'x'.$widhtHeight.' 
 &cht=qr&chld='.$EC_level.'|'.$margin.'&chl='.$chl.'" alt="QR code" widhtHeight="'.$widhtHeight.' 
 " widhtHeight="'.$widhtHeight.'"/>'; 
}

二、使用PHP二维码生成类库PHP QR Code生成二维码
 
PHP QR Code是一个PHP二维码生成类库,利用它可以轻松生成二维码,官网提供了下载和多个演示demo,查看地址:http://phpqrcode.sourceforge.net/。
下载官网提供的类库后,只需要使用phpqrcode.php就可以生成二维码了,当然您的PHP环境必须开启支持GD2。 phpqrcode.php提供了一个关键的png()方法,其中参数$text表示生成二位的的信息文本;参数$outfile表示是否输出二维码图片 文件,默认否;参数$level表示容错率,也就是有被覆盖的区域还能识别,分别是 L(QR_ECLEVEL_L,7%),M(QR_ECLEVEL_M,15%),Q(QR_ECLEVEL_Q,25%),H(QR_ECLEVEL_H,30%); 参数$size表示生成图片大小,默认是3;参数$margin表示二维码周围边框空白区域间距值;参数$saveandprint表示是否保存二维码并 显示。

public static function png($text, $outfile=false, $level=QR_ECLEVEL_L, $size=3, $margin=4, 
$saveandprint=false) 
{ 
 $enc = QRencode::factory($level, $size, $margin); 
 return $enc->encodePNG($text, $outfile, $saveandprint=false); 
}

调用PHP QR Code非常简单,如下代码即可生成一张内容为"https://3water.com"的二维码.
Php代码 
include 'phpqrcode.php';  
QRcode::png('https://3water.com');  
 
那么实际应用中,我们会在二维码的中间加上自己的LOGO,已增强宣传效果。那如何生成含有logo的二维码呢?其实原理很简单,先使用PHP QR Code生成一张二维码图片,然后再利用php的image相关函数,将事先准备好的logo图片加入到刚生成的原始二维码图片中间,然后重新生成一张新 的二维码图片。

include 'phpqrcode.php'; 
$value = 'https://3water.com'; //二维码内容 
$errorCorrectionLevel = 'L';//容错级别 
$matrixPointSize = 6;//生成图片大小 
//生成二维码图片 
QRcode::png($value, 'qrcode.png', $errorCorrectionLevel, $matrixPointSize, 2); 
$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; 
 $scale = $logo_width/$logo_qr_width; 
 $logo_qr_height = $logo_height/$scale; 
 $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); 
} 
//输出图片 
imagepng($QR, 'helloweba.png'); 
echo '<img src="helloweba.png">';

下面是参考上面的代码,不生产图片文件,方便调用的,将下面的代码保存为img.php

<?php
include 'phpqrcode.php'; 
$value = $_GET['url'];//二维码内容 
$errorCorrectionLevel = 'L';//容错级别 
$matrixPointSize = 6;//生成图片大小 
//生成二维码图片 
QRcode::png($value, 'qrcode.png', $errorCorrectionLevel, $matrixPointSize, 2); 
$logo = '3water.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; 
 $scale = $logo_width/$logo_qr_width; 
 $logo_qr_height = $logo_height/$scale; 
 $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); 
} 
//输出图片 
Header("Content-type: image/png");
ImagePng($QR);

调用方法:

<img src=http://test.3water.com:8080/qr/img.php?url=https://3water.com/1.rar>

由于二维码允许有一定的容错性,一般的二维码即使在遮住部分但仍然能够解码,经常我们扫描二维码的时候扫描到甚至不到一半时就能解码扫描结果,这是因为生成器会将部分信息重复表示来提高其容错度,这就是为什么我们在二维码中间加个LOGO图片并不影响解码结果的原因。
 

PS:本站还提供了一个功能十分强大的二维码工具供大家使用:

PHP 相关文章推荐
用PHP制作静态网站的模板框架
Oct 09 PHP
PHP strtr() 函数使用说明
Nov 21 PHP
php skymvc 一款轻量、简单的php
Jun 28 PHP
PHP文件大小格式化函数合集
Mar 10 PHP
php求两个目录的相对路径示例(php获取相对路径)
Mar 27 PHP
神盾加密解密教程(二)PHP 神盾解密
Jun 08 PHP
php 无限级分类,超级简单的无限级分类,支持输出树状图
Jun 29 PHP
PHP中常用的输出函数总结
Sep 22 PHP
php实现通用的信用卡验证类
Mar 24 PHP
PHP实现QQ、微信和支付宝三合一收款码实例代码
Feb 19 PHP
laravel 实现划分admin和home 模块分组
Oct 15 PHP
基于PHP实现邮箱验证激活过程详解
Oct 28 PHP
19个超实用的PHP代码片段
Mar 14 #PHP
php的zip解压缩类pclzip使用示例
Mar 14 #PHP
php多功能图片处理类分享(php图片缩放类)
Mar 14 #PHP
zf框架db类的分页示例分享
Mar 14 #PHP
zf框架的db类select查询器join链表使用示例(zend框架)
Mar 14 #PHP
zf框架的zend_cache缓存使用方法(zend框架)
Mar 14 #PHP
php实现天干地支计算器示例
Mar 14 #PHP
You might like
PHP insert语法详解
2008/06/07 PHP
php与paypal整合方法
2010/11/28 PHP
PHP和.net中des加解密的实现方法
2013/02/27 PHP
浅析php中常量,变量的作用域和生存周期
2013/08/10 PHP
PHP中如何实现常用邮箱的基本判断
2014/01/07 PHP
学习js所必须要知道的一些
2007/03/07 Javascript
非常棒的10款jQuery 幻灯片插件
2011/06/14 Javascript
javascript eval(func())使用示例
2013/12/05 Javascript
创建、调用JavaScript对象的方法集锦
2014/12/24 Javascript
推荐10 款 SVG 动画的 JavaScript 库
2015/03/24 Javascript
js实现简单折叠、展开菜单的方法
2015/08/28 Javascript
基于javascript实现九九乘法表
2016/03/27 Javascript
JS实现自动阅读单词(有道单词本添加功能)
2016/11/14 Javascript
angular+bootstrap的双向数据绑定实例
2017/03/03 Javascript
jQuery事件_动力节点Java学院整理
2017/07/05 jQuery
js canvas实现适用于移动端的百分比仪表盘dashboard
2017/07/18 Javascript
vue.js模仿京东省市区三级联动的选择组件实例代码
2017/11/22 Javascript
vue  elementUI 表单嵌套验证的实例代码
2019/11/06 Javascript
微信小程序实现抖音播放效果的实例代码
2020/04/11 Javascript
vue 表单输入框不支持focus及blur事件的解决方案
2020/11/17 Vue.js
学习python可以干什么
2019/02/26 Python
Python爬取腾讯视频评论的思路详解
2019/12/19 Python
Python变量作用域LEGB用法解析
2020/02/04 Python
浅析Python的命名空间与作用域
2020/11/25 Python
洛佩桑酒店官方网站:Lopesan Hotels
2019/04/15 全球购物
CAT鞋加拿大官网:CAT Footwear加拿大
2020/08/05 全球购物
艺术爱好者的自我评价分享
2013/10/08 职场文书
汽车销售员如何做职业生涯规划
2014/02/16 职场文书
上课说话检讨书500字
2014/11/01 职场文书
优秀班主任先进事迹材料
2014/12/16 职场文书
2014收银员工作总结范文
2014/12/16 职场文书
三方合作意向书范本
2015/05/09 职场文书
观后感格式
2015/06/19 职场文书
企业廉洁教育心得体会
2016/01/20 职场文书
导游词之云南省玉龙雪山
2019/12/19 职场文书
vue+elementui 实现新增和修改共用一个弹框的完整代码
2021/06/08 Vue.js