文档章节

JAVA整合HTML5实现扫描二维码功能项目源码

小柒2012
 小柒2012
发布于 2016/07/09 19:33
字数 969
阅读 1203
收藏 13

 最近一个需求就是做一个二维码扫描的功能,但是又不想使用安卓APP的方式实现,百度了一下貌似HTML5可以实现。


项目使用环境以及工具:

Eclipse,JDK1.7,struts2,HTML5,Jquery,QRCode

HTML5技术支持WebApp在手机上拍照,显示在页面上并上传到服务器。这是手机微博应用中常见的功能,当然你也可以在其它类型应用中适当使用此技术。


        这个功能不但手机端可以实现PC端也可以很好的实现,这个应用接口技术就是getUserMedia API,它能让应用开发者访问用户的摄像头或内置相机。下面就让我展示一下如何通过浏览器来访问你的摄像头,并提取截屏图形。

一、视频流 

      HTML5 的 The Media Capture(媒体捕捉) API 提供了对摄像头的可编程访问,用户可以直接用 getUserMedia (请注意目前仅Chrome和Opera支持)获得摄像头提供的视频流。我们需要做的是添加一个HTML5 的 Video 标签,并将从摄像头获得的视频作为这个标签的输入来源。

二、拍照

拍照是采用HTML5的Canvas功能,实时捕获Video标签的内容,因为Video元素可以作为Canvas图像的输入,所以这一点很好实现。

三、 获取图片

  从Canvas获取图片数据的核心思路是用canvas的toDataURL将Canvas的数据转换为base64位编码的PNG图像,类似于“”的格式。

var imgData=canvas.toDataURL(“image/png”);

这样,imgData变量就存储了一长串的字符数据内容,表示的就是一个PNG图像的base64编码。因为真正的图像数据是base64编码逗号之后的部分,所以要让实际服务器接收的图像数据应该是这部分,我们可以用两种办法来获取。
  第一种:是在前端截取22位以后的字符串作为图像数据,例如:

var data=imgData.substr(22);

  第二种:就是替换;前面的部分为"";

var image = canvas.toDataURL("image/png").replace("data:image/png;base64,", "");

反正不管如何实现,能获取到图片流即可、

四、上传图片并解析

使用 setInterval定时上传到项目后台使用开源QRCode.jar 解析图片获取二维码信息。

前台部分代码:

  1. <video  id="video">
  2. <script>
  3.     var flag = true;
  4.     window.addEventListener("DOMContentLoaded", function () {
  5.         var video = document.getElementById("video"), canvas, context;
  6.         try {
  7.             canvas = document.createElement("canvas");
  8.             canvas.width = 600;
  9.             canvas.height = 600;
  10.             context = canvas.getContext("2d");
  11.         } catch (e) { alert("not support canvas!"); return; }
  12.         navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;
  13.  
  14.         if (navigator.getUserMedia)
  15.             navigator.getUserMedia(
  16.                 { "video": true },
  17.                 function (stream) {
  18.                     if (video.mozSrcObject !== undefined)video.mozSrcObject = stream;
  19.                     else video.src = ((window.URL || window.webkitURL || window.mozURL || window.msURL) && window.URL.createObjectURL(stream)) || stream;               
  20.                     video.play();
  21.                 },
  22.                 function (error) {
  23.                     alert("请检查是否开启摄像头");
  24.                     flag = false;
  25.                 }
  26.             );
  27.         else alert("Native device media streaming (getUserMedia) not supported in this browser");
  28.        
  29.         setInterval(function () {
  30.                 if(!flag){
  31.                         return;
  32.                 }
  33.             context.drawImage(video, 0, 0, canvas.width = video.videoWidth, canvas.height = video.videoHeight);
  34.                     var image = canvas.toDataURL("image/png").replace("data:image/png;base64,", ""); 
  35.             $.ajax({
  36.                                 url : 'qRCodeAction_decoderQRCode.action',
  37.                                 async : false,
  38.                                 type : 'post',
  39.                                 data : {
  40.                                         'time' : (new Date()).toString(),
  41.                                         'img' : image
  42.                                 },
  43.                                 success : function(result) {
  44.                                           
  45.                                 },
  46.                     });
  47.         }, 5000);
  48.     }, false);
  49. </script>

复制代码


后台部分代码:

  1. /**
  2.          * 解析二维码
  3.          */
  4.         public String decoderQRCode(){
  5.                 try {
  6.                         String realpath = ServletActionContext.getServletContext().getRealPath("/file");
  7.                         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
  8.                         String imgName = sdf.format(new Date()) + ".png";
  9.                         String filePath = realpath+Constants.SF_FILE_SEPARATOR+imgName;
  10.                         OutputStream out = new FileOutputStream(filePath);
  11.                         QRCode.GenerateImage(img,out);//生成图片
  12.                         message   = QRCode.decoderQRCode(filePath);
  13.                 } catch (Exception e) {
  14.                         e.printStackTrace();
  15.                 }
  16.                 return Action.SUCCESS;
  17.         }

复制代码



调用电脑拍摄一定要允许操作。现在只需要HTML5的画布技术和javaScript,我们就能简单快速的操作用户的摄像头。手机不仅可以调用摄像头扫描,PC不仅仅能访问摄像头,而且利用HTML5强大的画布技术,我们可以给图片上加入各种迷人的滤镜效果。现在,在浏览器里用自己的摄像头给自己拍张照片吧!

 


 
有些手机可能无法调出摄像头,那就赶紧换手机吧,别out了。

附上演示地址:http://monitor.52itstyle.com/

© 著作权归作者所有

共有 人打赏支持
小柒2012
粉丝 122
博文 28
码字总数 30355
作品 0
青岛
程序员
私信 提问
加载中

评论(4)

杨小小玉
有完整案例代码吗?
zigzagroad
zigzagroad

引用来自“IT媛”的评论

引用来自“zigzagroad”的评论

还不错。建议最后加上finally块,在其中删除产生的临时图片文件
哈哈 就是为了 保存这些图片 你懂得21

原来如此
小柒2012
小柒2012

引用来自“zigzagroad”的评论

还不错。建议最后加上finally块,在其中删除产生的临时图片文件
哈哈 就是为了 保存这些图片 你懂得21
zigzagroad
zigzagroad
还不错。建议最后加上finally块,在其中删除产生的临时图片文件
【培训】JAVA微信插件开发培训:本周三(10月28日)腾讯课堂开讲

关于微信插件 微信插件活动如何开发??? 有粉丝的地方就有活动。社交媒体风行后,品牌活动大规模转移到微信上来,真实的社交关系链,对于微信营销活动来说是最好的人气资源,”大转盘”、“...

Jeecg
2015/10/28
0
0
简单Java代码执行过程转换为动画

我在想能不能把简单的Java代码执行过程转换为动画,这样可以方便初学者理解Java语法和JVM。 我的思路: 1. 编译Java代码获得字节码 2.使用html5的canvas画图将字节码的执行过程表现出来 主要...

魔神翼
2014/12/18
613
3
Java EE HTML5 WebSocket 示例

在这个教程中,我们将借助于Java EE websocket的实现(服务器端)来实现HTML5 的 websocket。 1.介绍 HTML5规范带来了使用websocket标准服务让浏览器建立全双工TCP链接的能力。 换言之,浏览...

oschina
2013/08/14
112.8K
64
经过糟糕一年后,Java 正沿着正确方向发展

在刚刚过去的 2012 年中,Java 的形象因为安全方面的问题大受影响,但它仍然是一个关键的企业软件开发平台。而 2013 年,用户可以期待新的版本发布,包括企业版 Java 和标准版 Java。 JDK 8 ...

oschina
2013/01/05
6.5K
19
ShearPhoto 2.0 发布,支持HTML5本地截取头像,支持美图秀秀特效,支持几十M数码相片压缩截取

从shearphoto 1.5直接跳跃到shearphoto 2.0,这是shearphoto重大革新。本来我是想shearphoto 1.6 、1.7、 1.8 慢慢升的,但是这样升级只会让shearphoto慢慢走向灭亡!结果我又辛苦了一个多星...

明哥先生
2015/09/05
3.2K
15

没有更多内容

加载失败,请刷新页面

加载更多

Cookie 显示用户上次访问的时间

import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServlet;import javax.serv......

gwl_
今天
1
0
网络编程

第14天 网络编程 今日内容介绍  网络通信协议  UDP通信  TCP通信 今日学习目标  能够辨别UDP和TCP协议特点  能够说出UDP协议下两个常用类名称  能够说出TCP协议下两个常用类名称...

stars永恒
今天
1
0
二进制相关

二进制 众所周知计算机使用的是二进制,数字的二进制是如何表示的呢? 实际就是逢二进一。比如 2 用二进制就是 10。那么根据此可以推算出 5的二进制等于 10*10+1 即为 101。 在计算机中,负数以...

NotFound403
昨天
3
0
day22:

1、写一个getinterface.sh 脚本可以接受选项[i,I],完成下面任务: 1)使用格式:getinterface.sh [-i interface | -I ip] 2)当用户使用-i选项时,显示指定网卡的IP地址;当用户使用-I选项...

芬野de博客
昨天
2
0
Spring Cloud Alibaba基础教程:使用Nacos实现服务注册与发现

自Spring Cloud Alibaba发布第一个Release以来,就备受国内开发者的高度关注。虽然Spring Cloud Alibaba还没能纳入Spring Cloud的主版本管理中,但是凭借阿里中间件团队的背景,还是得到不少...

程序猿DD
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部