這篇文章主要介紹了關於php產生二維碼的三種方法,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
最簡單最執行個體的goolge開源方法,不過反應有點慢
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='.$widhtHeight.'x'.$widhtHeight.' &cht=qr&chld='.$EC_level.'|'.$margin.'&chl='.$chl.'" alt="QR code" widhtHeight="'.$widhtHeight.' " widhtHeight="'.$widhtHeight.'"/>'; }
2.php類庫PHP QRCode
地址:http://phpqrcode.sourceforge.net/
下載:http://sourceforge.net/projects/phpqrcode/
下載官網提供的類庫後,只需要使用phpqrcode.php就可以產生二維碼了,當然您的PHP環境必須開啟支援GD2。phpqrcode.php提供了一個關鍵的png()方法,其中參數$frame表示產生的資訊文本;參數$filename 表示是否輸出二維碼圖片檔案(檔案路徑,包含圖片名和尾碼),預設否;參數$pixelPerPoint 表示容錯率,也就是有被覆蓋的地區還能識別參數,$outerFrame表示產生圖片大小,預設是4;參數$saveandprint表示是否儲存二維碼。
代碼如下:
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 Code:
<?phpinclude 'phpqrcode.php'; //只需要phpqrcode一個檔案即可,下載的裡面其他的沒什麼用QRcode::png('http://www.baidu.com');
實際應用中,我們會在二維碼的中間加上自己的LOGO,已增強宣傳效果。那如何產生含有logo的二維碼呢?其實原理很簡單,先使用PHP QRCode產生一張二維碼圖片,然後再利用php的image相關函數,將事先準備好的logo圖片加入到剛產生的原始二維碼圖片中間,然後重建一張新的二維碼圖片。
<?phpinclude './phpqrcode.php';QRcode::png('http://www.baidu.com','qrcode.png',2,10,true);$logo = 'logo.jpg';//準備好的logo圖片$QR = 'qrcode.png';//已經產生的原始二維碼圖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, 'newcode.png');echo '';
對於第二種方法:如果不使用$filename,第二個參數為false的時候,就不會把二維碼圖片儲存,而是直接輸出。
現在還有一些如有:libqrencode與QRcode Perl CGI & PHP scripts二維碼產生外掛程式大家喜歡也可看看。
3.基於jquery的二維碼產生外掛程式qrcode,在頁面中調用該外掛程式就能產生對應的二維碼。
qrcode其實是通過使用jQuery實現圖形渲染,畫圖,支援canvas(HTML5)和table兩種方式,
可以到https://github.com/jeromeetienne/jquery-qrcode擷取最新的代碼。
如何使用
(1)、首先在頁面中加入jquery庫檔案和qrcode外掛程式。
<script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="jquery.qrcode.min.js"></script>
(2)、在頁面中需要顯示二維碼的地方加入以下代碼:
<p id="code"></p>
(3)、調用qrcode外掛程式。
qrcode支援canvas和table兩種方式進行圖片渲染,預設使用canvas方式,效率最高,當然要瀏覽器支援html5。直接調用如下:
$('#code').qrcode("http://www.helloweba.com"); //任一字元串
您也可以通過以下方式調用:
$("#code").qrcode({ render: "table", //table方式 width: 200, //寬度 height:200, //高度 text: "www.helloweba.com" //任意內容 });
這樣就可以在頁面中直接產生一個二維碼,你可以用手機“掃一掃”功能讀取二維碼資訊。
識別中文
我們實驗的時候發現不能識別中文內容的二維碼,通過尋找多方資料瞭解到,jquery-qrcode是採用charCodeAt()方式進行編碼轉換的。而這個方法預設會擷取它的Unicode編碼,如果有中文內容,在產生二維碼前就要把字串轉換成UTF-8,然後再產生二維碼。您可以通過以下函數來轉換中文字串:
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);