Maison  >  Article  >  développement back-end  >  Explication détaillée de la façon dont PHP génère des codes QR basés sur la classe phpqrcode

Explication détaillée de la façon dont PHP génère des codes QR basés sur la classe phpqrcode

不言
不言original
2018-04-19 14:03:091665parcourir

L'exemple de cet article décrit comment PHP génère des codes QR basés sur la classe phpqrcode. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Il est assez difficile de générer des codes QR en langage PHP bien sûr, sauf pour appeler l'interface qui génère les images de codes QR (comme l'interface de Liantu http://www.liantu.com/), si vous écrivez le code vous-même. , Il n'y a vraiment aucun moyen de commencer. Cependant, nous pouvons utiliser phpqrcode, un fichier de classe prêt à l'emploi et une bibliothèque de classes de génération de code QR PHP, pour générer facilement des codes QR.

Préparation précoce :

1. Téléchargez le fichier de classe phpqrcode, adresse de téléchargement : https://sourceforge.net/projects/phpqrcode/
2. L'environnement PHP doit activer la prise en charge de la bibliothèque d'extension GD2 (généralement, elle est activée)

Interprétation de la méthode :

Le fichier de classe téléchargé est un package compressé contenant de nombreux fichiers et programmes de démonstration. Nous n'avons besoin que du fichier phpqrcode.php à l'intérieur pour générer le code QR. Il s'agit d'un fichier de collection de plusieurs classes. Nous devons utiliser la méthode png() (ligne 3090) de la classe QRcode (ligne 2963) à l'intérieur de :

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);
}

.

Le premier paramètre $text : le contenu contenu dans le code QR, qui peut être des liens, du texte, des chaînes json, etc.
le deuxième paramètre $outfile : la valeur par défaut est faux, aucun fichier n'est généré et seule l'image du code QR est renvoyée à la sortie ; sinon, le nom du fichier et le chemin pour stocker l'image du code QR générée doivent être donnés
Le troisième paramètre $level ;  : La valeur par défaut est L , les valeurs pouvant être transmises par ce paramètre sont L(QR_ECLEVEL_L, 7%), M(QR_ECLEVEL_M, 15%), Q(QR_ECLEVEL_Q, 25%), H(QR_ECLEVEL_H, 30 %). Ce paramètre contrôle le taux de tolérance d'erreur du code QR. Différents paramètres représentent le pourcentage de la zone qui peut être couverte par le code QR, c'est-à-dire que la zone couverte peut toujours être reconnue
Le quatrième paramètre$size : contrôle la taille de l'image générée, la valeur par défaut est 4 ; Le cinquième paramètre
$margin : contrôle la taille de la zone vide pour générer les codes QR Le sixième paramètre$saveandprint
 : Enregistre l'image du code QR et l'affiche, $outfile doit transmettre le chemin de l'image ;

Exemple d'utilisation : 1. Générer un code QR (générer un fichier image)

// 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 &#39;<img src="qrcode.png" alt="使用微信扫描支付">&#39;;
}
//调用查看结果
echo scerweima(&#39;https://www.baidu.com&#39;);

2. Ajoutez un logo au code QR généré (générer un fichier image)

//2. 在生成的二维码中加上logo(生成图片文件)
function scerweima1($url=&#39;&#39;){
  require_once &#39;phpqrcode.php&#39;;
  $value = $url;         //二维码内容
  $errorCorrectionLevel = &#39;H&#39;;  //容错级别
  $matrixPointSize = 6;      //生成图片大小
  //生成二维码图片
  $filename = &#39;qrcode/&#39;.microtime().&#39;.png&#39;;
  QRcode::png($value,$filename , $errorCorrectionLevel, $matrixPointSize, 2);
  $logo = &#39;qrcode/logo.jpg&#39;; //准备好的logo图片
  $QR = $filename;      //已经生成的原始二维码图
  if (file_exists($logo)) {
    $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 / 4;   //组合之后logo的宽度(占二维码的1/5)
    $scale = $logo_width/$logo_qr_width;  //logo的宽度缩放比(本身宽度/组合后的宽度)
    $logo_qr_height = $logo_height/$scale; //组合之后logo的高度
    $from_width = ($QR_width - $logo_qr_width) / 2;  //组合之后logo左上角所在坐标点
    //重新组合图片并调整大小
    /*
     * imagecopyresampled() 将一幅图像(源图象)中的一块正方形区域拷贝到另一个图像中
     */
    imagecopyresampled($QR, $logo, $from_width, $from_width, 0, 0, $logo_qr_width,$logo_qr_height, $logo_width, $logo_height);
  }
  //输出图片
  imagepng($QR, &#39;qrcode.png&#39;);
  imagedestroy($QR);
  imagedestroy($logo);
  return &#39;<img src="qrcode.png" alt="使用微信扫描支付">&#39;;
}
//调用查看结果
echo scerweima1(&#39;https://www.baidu.com&#39;);

Explication détaillée de la façon dont PHP génère des codes QR basés sur la classe phpqrcode 3. Générez du code QR (ne générez pas de fichiers image)

//3. 生成原始的二维码(不生成图片文件)
function scerweima2($url=&#39;&#39;){
  require_once &#39;phpqrcode.php&#39;;
  $value = $url;         //二维码内容
  $errorCorrectionLevel = &#39;L&#39;;  //容错级别
  $matrixPointSize = 5;      //生成图片大小
  //生成二维码图片
  $QR = QRcode::png($value,false,$errorCorrectionLevel, $matrixPointSize, 2);
}
//调用查看结果
scerweima2(&#39;https://www.baidu.com&#39;);

Les deux premières méthodes généreront une image de code QR localement à chaque appel. La troisième méthode ne génère pas de fichier et affichera directement le code QR dans le navigateur.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn