web/html5呼叫攝像頭實現二維碼掃描
阿新 • • 發佈:2019-02-18
閒話不說,直接上程式碼,本人測試通過!
html/js
<!DOCTYPE html> <html><head> <title>HTML5 code Reader</title> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> </head> <style type="text/css"> html, body { height: 100%; width: 100%; text-align:center; } </style> <script src="jquery-1.9.1.js"></script> <script> //這段代 主要是獲取攝像頭的視訊流並顯示在Video 籤中 var canvas=null,context=null,video=null; window.addEventListener("DOMContentLoaded", function () { try{ canvas = document.getElementById("canvas"); context = canvas.getContext("2d"); video = document.getElementById("video"); var videoObj = { "video": true,audio:false}, flag=true, MediaErr = function (error) { flag=false; if (error.PERMISSION_DENIED) { alert('使用者拒絕了瀏覽器請求媒體的許可權', '提示'); } else if (error.NOT_SUPPORTED_ERROR) { alert('對不起,您的瀏覽器不支援拍照功能,請使用其他瀏覽器', '提示'); } else if (error.MANDATORY_UNSATISFIED_ERROR) { alert('指定的媒體型別未接收到媒體流', '提示'); } else { alert('系統未能獲取到攝像頭,請確保攝像頭已正確安裝。或嘗試重新整理頁面,重試', '提示'); } }; //獲取媒體的相容程式碼,目前只支援(Firefox,Chrome,Opera) if (navigator.getUserMedia) { //qq瀏覽器不支援 if (navigator.userAgent.indexOf('MQQBrowser') > -1) { alert('對不起,您的瀏覽器不支援拍照功能,請使用其他瀏覽器', '提示'); return false; } navigator.getUserMedia(videoObj, function (stream) { video.src = stream; video.play(); }, MediaErr); } else if(navigator.webkitGetUserMedia) { navigator.webkitGetUserMedia(videoObj, function (stream) { video.src = window.webkitURL.createObjectURL(stream); video.play(); }, MediaErr); } else if (navigator.mozGetUserMedia) { navigator.mozGetUserMedia(videoObj, function (stream) { video.src = window.URL.createObjectURL(stream); video.play(); }, MediaErr); } else if (navigator.msGetUserMedia) { navigator.msGetUserMedia(videoObj, function (stream) { $(document).scrollTop($(window).height()); video.src = window.URL.createObjectURL(stream); video.play(); }, MediaErr); }else{ alert('對不起,您的瀏覽器不支援拍照功能,請使用其他瀏覽器'); return false; } if(flag){ alert('為了獲得更準確的測試結果,請儘量將二維碼置於框中,然後進行拍攝、掃描。 請確保瀏覽器有許可權使用攝像功能'); } //這個是拍照按鈕的事件, $("#snap").click(function () {startPat();}).show(); }catch(e){ printHtml("瀏覽器不支援HTML5 CANVAS"); } }, false); //列印內容到頁面 function printHtml(content){ $(window.document.body).append(content+"<br/>"); } //開始拍照 function startPat(){ setTimeout(function(){//防止呼叫過快 if(context) { context.drawImage(video, 0, 0, 320, 320); CatchCode(); } },200); } //抓屏獲取影象流,並上傳到伺服器 function CatchCode() { if(canvas!=null) { //以下開始編 資料 var imgData = canvas.toDataURL(); //將影象轉換為base64資料 var base64Data = imgData;//.substr(22); //在前端擷取22位之後的字串作為影象資料 //開始非同步上 $.post("saveimg.php", { "img": base64Data },function (result) { printHtml("解析結果:"+result.data); if (result.status == "success" && result.data!="") { printHtml("解析結果成功!"); }else{ startPat();//如果沒有解析出來則重新抓拍解析 } },"json"); } } </script> <body> <div id="support"></div> <div id="contentHolder"> <video id="video" width="320" height="320" autoplay> </video> <canvas style="display:none; background-color:#F00;" id="canvas" width="320" height="320"> </canvas> <br/> <button id="snap" style="display:none; height:50px; width:120px;">開始掃描</button> </div> </body></html>
php(saveimg)
<?php include_once("utils.php"); $base64_image_content=$_POST['img']; if (preg_match('/^(data:\s*image\/(\w+);base64,)/', $base64_image_content, $result)) { $type = $result[2]; $new_file = "./2.{$type}"; if (file_put_contents($new_file, base64_decode(str_replace($result[1], '', $base64_image_content)))){ $code=utils::deCodeBitMap("2.png","192.168.46.123",20147); echo '{"status":"success","data":"'.trim($code).'"}'; }else{ echo '{"status":"write error","data":"NO"}'; } }else{ echo '{"status":"preg error","data":"NO"}'; } ?>
php(utils)
java擴充套件使用說明class utils{ /** * @access static * @param $imagepath String 圖片的完整路徑 * @param $host String 主機如:127.0.0.1 * @param $port String 埠號如:20147 * @return string 解析出的URL */ static function deCodeBitMap($imagepath,$host,$port){ $socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP) or die($imagepath." Could not connet server create\n"); // 建立一個Socket if(!$socket){ return ""; } $connection = socket_connect($socket, $host, $port) or die($imagepath." Could not connet server connection\n"); // 連線 if(!$connection){ return ""; } socket_write($socket, $imagepath) or die("Write failed\n"); // 資料傳送 向伺服器傳送訊息 $buff = socket_read($socket, 1024, PHP_NORMAL_READ); return $buff; } }
該解析過程需要java環境支援,jar包啟動後在本機的20147埠接受socket監聽,因此網路程式語言都可以呼叫。
1 命令列啟動jar包
java -jar xxxxx.jar
啟動成功應該能看到20147埠的應用
2服務socket呼叫
暫提供php呼叫程式碼
最終效果:
程式已打包:在我的資源裡面,可自行下載!
瀏覽器支援情況