Maison  >  Article  >  développement back-end  >  La classe phpqrcode génère la méthode du code QR

La classe phpqrcode génère la méthode du code QR

小云云
小云云original
2018-03-16 10:28:361473parcourir

Il est assez difficile d'utiliser le langage PHP pour générer des codes QR, sauf pour appeler l'interface pour générer des images de code QR. Si vous écrivez le code pour le générer vous-même, vous n'avez 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éliminaire :

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

Interprétation de la méthode :

Télécharger Le fichier de classe fourni. down 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 la 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 Affiché, $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. Ajouter 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;);
3. Générer un code QR (ne pas générer 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 premiers Les méthodes généreront une image de code QR localement à chaque fois qu'elles sont appelées, la troisième méthode ne génère pas de fichier, mais envoie directement le code QR au navigateur.

Recommandations associées :

Bibliothèque de classes phpqrcode pour générer un exemple de code QR

Laravel utilise PHPQRCODE pour générer du code QR avec Image de code QR LOGO

Utilisez phpqrcode pour générer un exemple de code QR code_PHP tutoriel

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