Maison  >  Article  >  développement back-end  >  Générer un code QR à l'aide de phpqrcode

Générer un code QR à l'aide de phpqrcode

藏色散人
藏色散人avant
2019-12-13 14:57:004565parcourir

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 :

1.téléchargement du fichier de classe phpqrcode, adresse de téléchargement : https://sourceforge.net/projects/phpqrcode/

2 L'environnement .PHP doit être activé pour prendre en charge la bibliothèque d'extension GD2 (généralement activée)

Interprétation de la méthode :

Le fichier de classe téléchargé est un package compressé. Il contient de nombreux fichiers. et des programmes de démonstration. Nous n'avons besoin que du fichier phpqrcode.php à l'intérieur pour générer un 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 : bidimensionnel Le contenu. le code peut contenir 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é et seule l'image du code QR est renvoyée pour la sortie ; vous devez donner à Output le nom du fichier et le chemin pour stocker l'image du code QR généré ;

Le troisième paramètre $level : la valeur par défaut est L. Les valeurs qui peuvent ê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. le code QR peut être couvert, c'est-à-dire que la zone couverte est toujours Peut être reconnu

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

Générer un code QR à laide de phpqrcode3. 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 premières méthodes généreront une image de code QR localement à chaque fois qu'elles sont appelées. 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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer