PHP で QR コードを生成する 3 つの方法を共有します

藏色散人
リリース: 2023-04-09 16:20:01
転載
6220 人が閲覧しました

最もシンプルで最も実用的な Google オープンソースの方法ですが、応答が少し遅いです

1.Google オープン API

コードは次のとおりです:

$urlToEncode="http://www.helloweba.com";   
generateQRfromGoogle($urlToEncode);   
/**  
 * google api 二维码生成【QRcode可以存储最多4296个字母数字类型的任意文本,具体可以查看二维码数据格式】  
 * @param string $chl 二维码包含的信息,可以是数字、字符、二进制信息、汉字。  
 不能混合数据类型,数据必须经过UTF-8 URL-encoded  
 * @param int $widhtHeight 生成二维码的尺寸设置  
 * @param string $EC_level 可选纠错级别,QR码支持四个等级纠错,用来恢复丢失的、读错的、模糊的、数据。  
 *                            L-默认:可以识别已损失的7%的数据  
 *                            M-可以识别已损失15%的数据  
 *                            Q-可以识别已损失25%的数据  
 *                            H-可以识别已损失30%的数据  
 * @param int $margin 生成的二维码离图片边框的距离  
 */   
function generateQRfromGoogle($chl,$widhtHeight ='150',$EC_level='L',$margin='0')   
{   
    $chl = urlencode($chl);   
    echo '<img src="http://chart.apis.google.com/chart?chs=&#39;.$widhtHeight.&#39;x&#39;.$widhtHeight.&#39;   
    &cht=qr&chld=&#39;.$EC_level.&#39;|&#39;.$margin.&#39;&chl=&#39;.$chl.&#39;" alt="QR code" widhtHeight="&#39;.$widhtHeight.&#39;   
    " widhtHeight="&#39;.$widhtHeight.&#39;"/>';   
}
ログイン後にコピー

2.php クラス ライブラリ PHP QRCode

アドレス: http://phpqrcode.sourceforge.net/
ダウンロード: http://sourceforge.net/ project/phpqrcode/
公式サイトから提供されているクラスライブラリをダウンロードしたら、phpqrcode.php を使って QR コードを生成するだけですが、もちろん PHP 環境が GD2 をサポートしている必要があります。 phpqrcode.php はキー png() メソッドを提供し、パラメータ $frame は生成された情報テキストを表し、パラメータ $filename QR コード画像ファイル (画像名とサフィックスを含むファイル パス) を出力するかどうかを示します。デフォルトは no です。パラメータ $pixelPerPoint はフォールト トレランス レートを示します。つまり、カバーされる領域は依然として出力可能です。パラメータを認識します。#$outerFrame は生成される画像のサイズを示し、デフォルトは 4 です。パラメータ $saveandprint は QR コードを保存するかどうかを示します。

コードは次のとおりです:

public static function png($frame, $filename = false, $pixelPerPoint = 4, $outerFrame = 4,$saveandprint=FALSE) 
        {
            $image = self::image($frame, $pixelPerPoint, $outerFrame);
            
            if ($filename === false) {
                Header("Content-type: image/png");
                ImagePng($image);
            } else {
                if($saveandprint===TRUE){
                    ImagePng($image, $filename);
                    header("Content-type: image/png");
                    ImagePng($image);
                }else{
                    ImagePng($image, $filename);
                }
            }
            
            ImageDestroy($image);
        }
ログイン後にコピー
PHP QR コードの呼び出し:

<?php
include &#39;phpqrcode.php&#39;;   //只需要phpqrcode一个文件即可,下载的里面其他的没什么用
QRcode::png(&#39;http://www.baidu.com&#39;);
ログイン後にコピー

実際のアプリケーションでは、機能を強化するために QR コードの途中に独自のロゴを追加します。宣伝効果。では、ロゴを含む QR コードを生成するにはどうすればよいでしょうか?実は原理は非常に単純で、まずPHP

QRCodeを使ってQRコード画像を生成し、次にPHPのimage関連関数を使ってあらかじめ用意されたロゴ画像を新たに追加します。生成された元の QR コード画像を QR コード画像の中央に配置し、新しい QR コード画像を再生成します。

<?php
include &#39;./phpqrcode.php&#39;;
QRcode::png(&#39;http://www.baidu.com&#39;,&#39;qrcode.png&#39;,2,10,true);
$logo = &#39;logo.jpg&#39;;//准备好的logo图片
$QR = &#39;qrcode.png&#39;;//已经生成的原始二维码图
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);
}
//输出图片
imagepng($QR, &#39;newcode.png&#39;);
echo &#39;![](./newcode.png)&#39;;
ログイン後にコピー

2 番目の方法の場合: $filename が使用されず、2 番目のパラメータが false の場合、QR コード画像は保存されず、直接出力されます。

libqrencode と QRcode Perl CGI および PHP スクリプト QR コード生成プラグインも必要に応じていくつかあります。

3. jqueryベースのQRコード生成プラグインqrcodeは、ページ上でプラグインを呼び出すことで対応するQRコードを生成できます。 qrcode は実際に jQuery を使用してグラフィックスのレンダリングと描画を実現し、キャンバス (HTML5) とテーブルをサポートします。
最新バージョンは https://github.com/jeromeetienne/jquery-qrcode code で入手できます。

使い方

(1)では、まずjqueryライブラリファイルとqrcodeプラグインをページに追加します。

<script type="text/javascript" src="jquery.js"></script> 
<script type="text/javascript" src="jquery.qrcode.min.js"></script>
ログイン後にコピー
(2). QR コードを表示する必要があるページに次のコードを追加します:

<p id="code"></p>
ログイン後にコピー
(3). qrcode プラグインを呼び出します。

qrcode は、画像のレンダリングにキャンバス メソッドとテーブル メソッドをサポートしています。キャンバス メソッドがデフォルトで使用され、これが最も効率的です。もちろん、ブラウザは html5 をサポートしている必要があります。次のように直接呼び出します:

$('#code').qrcode("http://www.helloweba.com"); //任意字符串
ログイン後にコピー
次の方法で呼び出すこともできます:

$("#code").qrcode({ 
    render: "table", //table方式 
    width: 200, //宽度 
    height:200, //高度 
    text: "www.helloweba.com" //任意内容 
});
ログイン後にコピー
これにより、ページ上に QR コードが直接生成され、「スキャン」機能が使用できるようになります。携帯電話のQRコードを読み取ってQRコード情報を取得します。

中国語の認識

テストしたところ、中国語のコンテンツが含まれるQRコードは認識できないことがわかり、いろいろ調べた結果、jquery-qrcodeは次のことを使用していることがわかりました。 charCodeAt() メソッド コード変換。このメソッドはデフォルトで Unicode エンコードを取得します。中国語のコンテンツがある場合は、QR コードを生成する前に文字列を UTF-8 に変換する必要があり、その後 QR コードが生成されます。次の関数で中国語の文字列を変換できます:

function toUtf8(str) {    
    var out, i, len, c;    
    out = "";    
    len = str.length;    
    for(i = 0; i < len; i++) {    
        c = str.charCodeAt(i);    
        if ((c >= 0x0001) && (c <= 0x007F)) {    
            out += str.charAt(i);    
        } else if (c > 0x07FF) {    
            out += String.fromCharCode(0xE0 | ((c >> 12) & 0x0F));    
            out += String.fromCharCode(0x80 | ((c >>  6) & 0x3F));    
            out += String.fromCharCode(0x80 | ((c >>  0) & 0x3F));    
        } else {    
            out += String.fromCharCode(0xC0 | ((c >>  6) & 0x1F));    
            out += String.fromCharCode(0x80 | ((c >>  0) & 0x3F));    
        }    
    }    
    return out;    
}
ログイン後にコピー
以下の例:

var str = toUtf8("随便来点啥"); 
$('#code').qrcode(str);
ログイン後にコピー

以上がPHP で QR コードを生成する 3 つの方法を共有しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
php
ソース:jianshu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート