1.phpqrcode类文件下载,下载地址:https://sourceforge.net/projects/phpqrcode/
2.PHP环境必须开启支持GD2扩展库支持(一般情况下都是开启状态)
方法解读:
下载下来的类文件是一个压缩包,里边包含很多文件和演示程序,我们只需要里边的phpqrcode.php这一个文件就可以生成二维码了。它是一个多个类的集合文件,我们需要用到里边的QRcode类(第2963行)的png()方法(第3090行):
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);
}
第1个参数$text:二维码包含的内容,可以是链接、文字、json字符串等等;
第2个参数$outfile:默认为false,不生成文件,只将二维码图片返回输出;否则需要给出存放生成二维码图片的文件名及路径;
第3个参数$level:默认为L,这个参数可传递的值分别是L(QR_ECLEVEL_L,7%)、M(QR_ECLEVEL_M,15%)、Q(QR_ECLEVEL_Q,25%)、H(QR_ECLEVEL_H,30%),这个参数控制二维码容错率,不同的参数表示二维码可被覆盖的区域百分比,也就是被覆盖的区域还能识别;
第4个参数$size:控制生成图片的大小,默认为4;
第5个参数$margin:控制生成二维码的空白区域大小;
第6个参数$saveandprint:保存二维码图片并显示出来,$outfile必须传递图片路径;
使用示例:
第一种:生成二维码文件
网上原有例子
// 1. 生成原始的二维码(生成图片文件)
function scerweima($url=''){
require_once 'phpqrcode.php';
$value = $url; //二维码内容
$errorCorrectionLevel = 'L'; //容错级别
$matrixPointSize = 5; //生成图片大小
//生成二维码图片
$filename = 'qrcode/'.microtime().'.png';
QRcode::png($value,$filename , $errorCorrectionLevel, $matrixPointSize, 2);
$QR = $filename; //已经生成的原始二维码图片文件
$QR = imagecreatefromstring(file_get_contents($QR));
//输出图片
imagepng($QR, 'qrcode.png');
imagedestroy($QR);
return '<img src="qrcode.png" alt="使用微信扫描支付">';
}
//调用查看结果
echo scerweima('https://www.baidu.com');
自己改过适用于自己的项目 其实就是将 $QR = $filename 就是生成的文件名 后面的是将文件输出 没用太大作用
/**
* 生成二维码图片
* @param $url 手机扫描后要跳转的网址
* @param $level 默认纠错比例 分为L、M、Q、H四个等级,H代表最高纠错能力
* @param $size 二维码图大小,1-10可选,数字越大图片尺寸越大
*/
private function scerweima($url,$level='L',$size='6'){
vendor('phpqrcode.phpqrcode');
$value = $url; //二维码内容
$errorCorrectionLevel = $level; //容错级别
$matrixPointSize = $size; //生成图片大小
//生成二维码图片
$filename = C(SAVE_QRCODE_PATH).random_filename().'.png';
QRcode::png($value,$filename,$errorCorrectionLevel, $matrixPointSize,2);
$QR = $filename; //已经生成的原始二维码图片文件
return $QR;
}
第二种例子:生成二维码文件 ----- 使用logo文件
封盛公司用的项目案例
/**
* 生成二维码图片
* @param $url 手机扫描后要跳转的网址
* @param $level 默认纠错比例 分为L、M、Q、H四个等级,H代表最高纠错能力
* @param $size 二维码图大小,1-10可选,数字越大图片尺寸越大
* @param $logoimg 准备好的logo图片的路径
*/
function QRimg($url,$level='L',$size='6',$logoimg='./Public/qrcode/logo.jpg'){
vendor('phpqrcode.phpqrcode');
$value = $url; //二维码内容
$errorCorrectionLevel = $level;//容错级别
$matrixPointSize = $size;//生成图片大小
//生成二维码图片
\QRcode::png($value,'./Public/qrcode/qrcode.png',$errorCorrectionLevel,$matrixPointSize, 2);
$logo = $logoimg;//准备好的logo图片
$QR = './Public/qrcode/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);
}
$path = './Public/qrimg/';
if(!is_dir($path)) {
$r = mkdir($path, 0777, true);
if(!$r){
$this->error('创建文件夹失败');
}
}
imagepng($QR, md5(time()).'.png');
$file = './'.md5(time()).'.png'; //旧目录
$newFile = $path.md5(time()).'.png'; //新目录
copy($file,$newFile); //拷贝到新目录
unlink($file); //删除旧目录下的文件
$path = substr($path,1);
$imgsrc = $path.md5(time()).".png";
return $imgsrc;
}
第三种:不生成文件 直接输出二维码
//3. 生成原始的二维码(不生成图片文件)
function scerweima2($url=''){
require_once 'phpqrcode.php';
$value = $url; //二维码内容
$errorCorrectionLevel = 'L'; //容错级别
$matrixPointSize = 5; //生成图片大小
//生成二维码图片
$QR = QRcode::png($value,false,$errorCorrectionLevel, $matrixPointSize, 2);
}
//调用查看结果
scerweima2('https://www.baidu.com');
总结 前两种生成二维码文件 最后一种不生成二维码文件 (第二个参数有路径就生成文件到指定目录 如果为false就不生成文件)