www.adminn.cn
站长正能量分享网!

php生成带logo二维码方法小结

AD:阿里云服务器企业会员更优惠 腾讯云香港,韩国免备案服务器1.8折优惠

本文给大家对比介绍了常用的2种生成带logo二维码的实现方法,非常的实用,有需要的小伙伴可以根据自己的需求来选择。

一、使用的类库

1、phpqrcode(php库)

2、qrcode.js(javascript库)

二、phpqrcode的使用

只用php的类库,也就是二维码的生成在后台操作。因为要在后台生成带logo的二维码,那么首先必须将logo图片上传至服务器(在上传这里我用了webuploader)

phpqrcode使用方法:

首先下载phpqrcode:http://phpqrcode.sourceforge.net/

然后在使用之前记得引入phpqrcode.php文件

  1. $value = $url;//二维码内容  
  2. $errorCorrectionLevel = 'L';//设置容错级别  
  3. $matrixPointSize = $size;//生成图片大小  
  4. QRcode::png($value'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .'qrcode.png'$errorCorrectionLevel$matrixPointSize, 2);//生成二维码图片 无logo 
  5. $logo = $tar_path;//上传至服务器的logo图片  
  6. $QR = 'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .'qrcode.png';//已经生成的原始二维码图 
  7.    
  8. if ($logo !== FALSE) { 
  9.   $QR = imagecreatefromstring(file_get_contents($QR)); 
  10.   $logo = imagecreatefromstring(file_get_contents($logo)); 
  11.   $QR_width = imagesx($QR);//二维码图片宽度 
  12.   $QR_height = imagesy($QR);//二维码图片高度 
  13.   $logo_width = imagesx($logo);//logo图片宽度 
  14.   $logo_height = imagesy($logo);//logo图片高度 
  15.   $logo_qr_width = $QR_width / 5; 
  16.   $scale = $logo_width/$logo_qr_width
  17.   $logo_qr_height = $logo_height/$scale
  18.   $from_width = ($QR_width – $logo_qr_width) / 2; 
  19.   imagecopyresampled($QR$logo$from_width$from_width, 0, 0, $logo_qr_width
  20.     $logo_qr_height$logo_width$logo_height); 
  21. $name = time(); 
  22. imagepng($QR'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .$name.'.png');//输出带logo的二维码图片 

三、qrcode.js的使用

使用qrcode.js在前端直接生成二维码,首先需要下载jquery.qrcode.js

qrcode的使用也很简单:

  1. var length = size*80;//设置二维码大小 
  2. length = parseInt(length); 
  3. $("#code_img").qrcode({ //code_img是一个img标签的id 
  4.   render : "canvas",  //设置渲染方式,有table和canvas,使用canvas方式渲染性能相对来说比较好 
  5.   text : url,  //扫描二维码后显示的内容,可以直接填一个网址,扫描二维码后自动跳向该链接 
  6.   width : length,       //二维码的宽度 
  7.   height : length, 
  8.   background : "#ffffff",    //二维码的后景色 
  9.   foreground : "#000000",    //二维码的前景色 
  10.   src: $('#image').attr('src')       //二维码中间的图片 
  11. }); 

引入jquery.qrcode.js后再自己编写这段js代码,执行后二维码就可以显示处理了

主要是二维码中间的logo引用格式,一般取本地图片有两种格式:一种是本地URL,另一种是将图片转成base64格式

一开始我试用本地URL的格式来引用图片,发现只能引用与js文件统一目录下的图片,所以本地URL格式并不支持,于是我采用了后一种方式。

用:<input accept="image/*" type="file" id="file_input">

来上传选取本地图片,然后取其base64格式

  1. var input = document.getElementById("file_input"); 
  2.    
  3. if(typeof FileReader==='undefined'){ 
  4.   input.setAttribute('disabled','disabled'); 
  5. }else
  6.   input.addEventListener('change',readFile,false); 
  7.    
  8. function readFile(){ 
  9.   var file = this.files[0]; 
  10.   if(!/image\/\w+/.test(file.type)){ 
  11.     alert("文件必须为图片!"); 
  12.     return false; 
  13.   } 
  14.   var reader = new FileReader(); 
  15.   reader.readAsDataURL(file); 
  16.   reader.onload = function(e){ 
  17.     $('#image').attr('src',this.result);//image为img标签的id 
  18.   } 

将文件读取为一串Data URL字符串,将小文件以一种特殊格式的URL地址直接读入页面。这个特殊格式就是base64

三、两个类库之间的对比

两个类库,一个在后台操作,一个直接在前端操作。

phpqrcode 生成二维码在后台操作,生成的图片保存在服务器。一般生成二维码都是直接保存到本地然后直接使用,很少会去服务器二次获取,所以采用phpqrcode的 话会使得服务器中的图片堆积,占用了不必要的空间,删除的话也会花费多余的开销。所以使用phpqrcode不适用于这种二维码生成工具。而且上传图片也 会产生多余的开销

qrcode.js直接在前端操作,上传图片直接保存在浏览器,直接在前端生成二维码,不需要任何后台的干涉,这样减少了不必要的开销,也不会在服务器造成图片的堆积而占用不必要的空间。

模板优惠价: (点击购买)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《php生成带logo二维码方法小结》
文章链接:https://www.adminn.cn/news/34624.html
本站资源模板仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。2021.5月起,网站调整,暂不再分享免费模板。谢谢理解

Adminn.Cn 站长分享圈

帝国CMS精品模板腾讯云优惠券,代金券

本站源码仅供本地环境下学习借鉴研究使用!

源码请勿用于任何涉灰站点!净化网络,站长更有责!

支付宝扫一扫打赏