Maison >développement back-end >tutoriel php >Explication détaillée de la classe phpqrcode pour générer du code QR
Cette fois, je vais vous apporter une explication détaillée du code QR généré par la classe phpqrcode. Quelles sont les précautions pour générer le code QR par la classe phpqrcode. Ce qui suit est un cas pratique, allons-y. jetez un oeil.
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 un code QR en utilisant le langage PHP. Bien sûr, l'interface de génération d'image de code QR s'appelle (par exemple : Liantu. com http://www .liantu.com/ interface), si vous écrivez le code pour le générer vous-même, vous n'avez vraiment aucun moyen de démarrer. Cependant, nous pouvons utiliser phpqrcode, un fichier de classe prêt à l'emploi, Bibliothèque de classes de génération de code QR PHP, qui peut facilement générer des codes QR.
Préparation préliminaire :
Classe 1.phpqrcodeTéléchargement de fichiers, 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 :
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 :
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 peut être des liens, du texte, des chaînes json, etc. ;
Le deuxième paramètre$outfile : La valeur par défaut est false, aucun fichier n'est généré, renvoie uniquement le Image du code QR à la sortie ; sinon vous devez donner le nom du fichier et le chemin pour stocker l'image du code QR générée
Le troisième paramètre$level : La valeur par défaut est L, la valeur qui peut être passés par ce paramètre Ils 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 code QR. Le pourcentage de la zone pouvant être couverte, c'est-à-dire que la zone couverte peut toujours être identifiée
Le 4ème paramètre$size : Contrôle la taille de l'image générée ; , la valeur par défaut est 4 ;
Le 5ème paramètre $margin : Contrôler la taille de la zone vide pour générer les codes QR
Le sixième paramètre$saveandprint : Enregistrez le Image du code QR et affichez-la, $outfile doit transmettre le chemin de l'image ;
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 '<img src="qrcode.png" alt="使用微信扫描支付">'; } //调用查看结果 echo scerweima('https://www.baidu.com');
2. Ajouter un logo au code QR généré (générer un fichier image)
//2. 在生成的二维码中加上logo(生成图片文件) function scerweima1($url=''){ require_once 'phpqrcode.php'; $value = $url; //二维码内容 $errorCorrectionLevel = 'H'; //容错级别 $matrixPointSize = 6; //生成图片大小 //生成二维码图片 $filename = 'qrcode/'.microtime().'.png'; QRcode::png($value,$filename , $errorCorrectionLevel, $matrixPointSize, 2); $logo = 'qrcode/logo.jpg'; //准备好的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, 'qrcode.png'); imagedestroy($QR); imagedestroy($logo); return '<img src="qrcode.png" alt="使用微信扫描支付">'; } //调用查看结果 echo scerweima1('https://www.baidu.com');
3. . Générer un code QR (ne pas générer de fichier image) )
//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');
Les deux premières méthodes généreront une image de code QR localement à chaque appel. La troisième méthode générera directement le code QR. au navigateur sans générer de fichier.
Je pense que vous maîtrisez la méthode après avoir lu le cas présenté dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le sujet. Site Web chinois PHP !
Lecture recommandée :
Explication détaillée du déploiement de mysqld_multi sur une seule machine
Résumé de quelques pièges MySQL
Comment faire fonctionner les tables dans Bootstrap
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!