溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

利用php怎么實現一個帶logo二維碼生成功能

發布時間:2020-12-14 16:26:34 來源:億速云 閱讀:283 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關利用php怎么實現一個帶logo二維碼生成功能,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

一、使用的類庫

1、phpqrcode(php庫)

2、qrcode.js(javascript庫)

二、phpqrcode的使用

只用php的類庫,也就是二維碼的生成在后臺操作。因為要在后臺生成帶logo的二維碼,那么首先必須將logo圖片上傳至服務器(在上傳這里我用了webuploader)

phpqrcode使用方法:

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

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

$value = $url;//二維碼內容 
$errorCorrectionLevel = 'L';//設置容錯級別 
$matrixPointSize = $size;//生成圖片大小 
QRcode::png($value, 'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .'qrcode.png', $errorCorrectionLevel, $matrixPointSize, 2);//生成二維碼圖片 無logo
$logo = $tar_path;//上傳至服務器的logo圖片 
$QR = 'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .'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);
}
$name = time();
imagepng($QR, 'public_files'.DIRECTORY_SEPARATOR .'code'.DIRECTORY_SEPARATOR .$name.'.png');//輸出帶logo的二維碼圖片

三、qrcode.js的使用

使用qrcode.js在前端直接生成二維碼,首先需要下載jquery.qrcode.js

qrcode的使用也很簡單:

var length = size*80;//設置二維碼大小
length = parseInt(length);
$("#code_img").qrcode({ //code_img是一個img標簽的id
  render : "canvas",  //設置渲染方式,有table和canvas,使用canvas方式渲染性能相對來說比較好
  text : url,  //掃描二維碼后顯示的內容,可以直接填一個網址,掃描二維碼后自動跳向該鏈接
  width : length,       //二維碼的寬度
  height : length,
  background : "#ffffff",    //二維碼的后景色
  foreground : "#000000",    //二維碼的前景色
  src: $('#image').attr('src')       //二維碼中間的圖片
});

引入jquery.qrcode.js后再自己編寫這段js代碼,執行后二維碼就可以顯示處理了

主要是二維碼中間的logo引用格式,一般取本地圖片有兩種格式:一種是本地URL,另一種是將圖片轉成base64格式

一開始我試用本地URL的格式來引用圖片,發現只能引用與js文件統一目錄下的圖片,所以本地URL格式并不支持,于是我采用了后一種方式。

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

來上傳選取本地圖片,然后取其base64格式

var input = document.getElementById("file_input");
 
if(typeof FileReader==='undefined'){
  input.setAttribute('disabled','disabled');
}else{
  input.addEventListener('change',readFile,false);
}
 
function readFile(){
  var file = this.files[0];
  if(!/image\/\w+/.test(file.type)){
    alert("文件必須為圖片!");
    return false;
  }
  var reader = new FileReader();
  reader.readAsDataURL(file);
  reader.onload = function(e){
    $('#image').attr('src',this.result);//image為img標簽的id
  }
}

將文件讀取為一串Data URL字符串,將小文件以一種特殊格式的URL地址直接讀入頁面。這個特殊格式就是base64

三、兩個類庫之間的對比

兩個類庫,一個在后臺操作,一個直接在前端操作。

phpqrcode 生成二維碼在后臺操作,生成的圖片保存在服務器。一般生成二維碼都是直接保存到本地然后直接使用,很少會去服務器二次獲取,所以采用phpqrcode的 話會使得服務器中的圖片堆積,占用了不必要的空間,刪除的話也會花費多余的開銷。所以使用phpqrcode不適用于這種二維碼生成工具。而且上傳圖片也 會產生多余的開銷

qrcode.js直接在前端操作,上傳圖片直接保存在瀏覽器,直接在前端生成二維碼,不需要任何后臺的干涉,這樣減少了不必要的開銷,也不會在服務器造成圖片的堆積而占用不必要的空間。

關于利用php怎么實現一個帶logo二維碼生成功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女