HTML打开摄像头,进行拍照上传

html代码

 1 <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
 2 <%@ include file="/includes/ctx.jsp" %>
 3 <!DOCTYPE html>
 4 <html>
 5 <head>
 6 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 7 <title>webcam</title>
 8     <script type="text/javascript" src="${ctx}/js/jquery-1.11.2.js"></script>
 9     <script type="text/javascript">
10      window.onload = function (){
11          try{
12              //动态创建一个canvas元 ,并获取他2Dcontext。如果出现异常则表示不支持
13              document.createElement("canvas").getContext("2d");
14              document.getElementById("support").innerHTML = "浏览器支持HTML5 CANVAS";
15          }catch(e){
16              document.getElementById("support").innerHTML = "浏览器不支持HTML5 CANVAS";
17          }
18      };
19 
20      //这段代 主要是获取摄像头的视频流并显示在Video 签中
21      window.addEventListener("DOMContentLoaded", function () {
22          var video = document.getElementById("video");
23          var videoObj = { "video": true };
24          var errBack = function (error){
25                  console.log("Video capture error: " + error.message, error.code);
26              };
27          //  支持浏览器  谷歌,火狐,360,欧朋
28          //navigator.getUserMedia这个写法在Opera中好像是navigator.getUserMedianow
29          if (navigator.getUserMedia) {
30              navigator.getUserMedia(videoObj, function (stream) {
31                  video.src = stream;
32                  video.play();
33              }, errBack);
34          } else if (navigator.webkitGetUserMedia) {
35              navigator.webkitGetUserMedia(videoObj, function (stream) {
36                  video.src = window.URL.createObjectURL(stream);
37                  video.play();
38              }, errBack);
39          } else if (navigator.mozGetUserMedia){
40              navigator.mozGetUserMedia(videoObj, function (stream) {
41                       video.src = window.URL.createObjectURL(stream);
42                      video.play();
43              }, errBack);
44          }
45          
46          
47          //这个是拍照按钮的事件,
48          document.getElementById("snap").addEventListener("click",function(){
49                  CatchCode();
50          });
51      }, false);
52      //定时器
53      //var interval = setInterval(CatchCode, "300");
54      //这个是 刷新上 图像的
55      function CatchCode() {
56          //实际运用可不写,测试代 , 为单击拍照按钮就获取了当前图像,有其他用途
57          var canvans = document.getElementById("canvas");
58          var video = document.getElementById("video");
59          var context = canvas.getContext("2d");
60 
61          canvas.width = video.videoWidth;
62          canvas.height = video.videoHeight;
63          context.drawImage(video,0,0);
64          
65          //获取浏览器页面的画布对象
66          //以下开始编 数据
67          var imgData = canvans.toDataURL("image/jpg");
68          //将图像转换为base64数据
69          var base64Data = imgData.split(",")[1];
70 
71          var xhr = new XMLHttpRequest();
72          xhr.open("post", "${ctx}/webcam.do", true);
73          //告诉服务器是以个Ajax 请求
74          xhr.setRequestHeader("X-Requested-Width", "XMLHttpRequest");
75          var fd = new FormData();
76          fd.append("doc",base64Data);
77          xhr.send(fd);
78 
79          //alert(base64Data);
80 
81          //在前端截取22位之后的字符串作为图像数据
82          //开始异步上
83      }
84     </script>
85 </head>
86     <body>
87         <div id="support"></div>
88         <div id="contentHolder">       
89             <video id="video" width="160" height="120" style="border:1px solid red" autoplay></video>       
90             <button id="snap"> 拍照</button>        
91             <canvas style="border:1px solid red" id="canvas"></canvas> 
92         </div>
93     </body>
94 </html>

 

后台代码

 

  1 package com.servlet;
  2 
  3 import java.io.File;
  4 import java.io.FileOutputStream;
  5 import java.io.IOException;
  6 import java.io.InputStream;
  7 import java.io.OutputStream;
  8 import java.util.Date;
  9 import java.util.List;
 10 
 11 import javax.servlet.ServletException;
 12 import javax.servlet.http.HttpServlet;
 13 import javax.servlet.http.HttpServletRequest;
 14 import javax.servlet.http.HttpServletResponse;
 15 
 16 import org.apache.commons.fileupload.FileItem;
 17 import org.apache.commons.fileupload.FileUploadException;
 18 import org.apache.commons.fileupload.disk.DiskFileItemFactory;
 19 import org.apache.commons.fileupload.servlet.ServletFileUpload;
 20 
 21 import sun.misc.BASE64Decoder;
 22 
 23 /**
 24  * Servlet implementation class webcam
 25  */
 26 public class webcam extends HttpServlet {
 27     private static final long serialVersionUID = 1L;
 28 
 29     /**
 30      * @see HttpServlet#HttpServlet()
 31      */
 32     public webcam() {
 33         super();
 34         // TODO Auto-generated constructor stub
 35     }
 36 
 37     /**
 38      * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse
 39      *      response)
 40      */
 41     protected void doGet(HttpServletRequest request,
 42             HttpServletResponse response) throws ServletException, IOException {
 43         // TODO Auto-generated method stub
 44         doPost(request, response);
 45     }
 46 
 47     /**
 48      * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse
 49      *      response)
 50      */
 51     protected void doPost(HttpServletRequest request,
 52             HttpServletResponse response) throws ServletException, IOException {
 53         request.setCharacterEncoding("utf-8");
 54         response.setCharacterEncoding("utf-8");
 55         response.setContentType("text/html;char=utf-8");
 56 
 57         // 获得磁盘文件条目工厂
 58         DiskFileItemFactory factory = new DiskFileItemFactory();
 59         // 获取文件需要上传到的路径
 60         // String path = request.getRealPath("/upload");
 61         String path = "d:/shangchuan/";
 62 
 63         // 如果文件夹不存在 将创建文件夹
 64         if (!new File(path).exists()) {
 65             new File(path).mkdirs();
 66         }
 67 
 68         // 如果没以下两行设置的话,上传大的 文件 会占用 很多内存,
 69         // 设置暂时存放的 存储室 , 这个存储室,可以和 最终存储文件 的目录不同
 70         /**
 71          * 原理 它是先存到 暂时存储室,然后在真正写到 对应目录的硬盘上, 按理来说 当上传一个文件时,其实是上传了两份,第一个是以 .tem
 72          * 格式的 然后再将其真正写到 对应目录的硬盘上
 73          */
 74         factory.setRepository(new File(path));
 75         // 设置 缓存的大小,当上传文件的容量超过该缓存时,直接放到 暂时存储室
 76         factory.setSizeThreshold(1024 * 1024);
 77 
 78         // 高水平的API文件上传处理
 79         ServletFileUpload upload = new ServletFileUpload(factory);
 80 
 81         try {
 82             // 可以上传多个文件
 83             List<FileItem> list = (List<FileItem>) upload.parseRequest(request);
 84 
 85             for (FileItem item : list) {
 86                 // 获取表单的属性名字
 87                 String name = item.getFieldName();
 88 
 89                 // 如果获取的 表单信息是普通的 文本 信息
 90                 if (item.isFormField()) {
 91                     // 获取用户具体输入的字符串 ,名字起得挺好,因为表单提交过来的是 字符串类型的
 92                     String imgStr = item.getString();
 93 
 94                     // base64解码并生成图片
 95                     BASE64Decoder decoder = new BASE64Decoder();
 96                     try {
 97                         // Base64解码
 98                         byte[] bytes = decoder.decodeBuffer(imgStr);
 99 //                        for (int i = 0; i < bytes.length; ++i) {
100 //                            if (bytes[i] < 0) {// 调整异常数据
101 //                                bytes[i] += 256;
102 //                            }
103 //                        }
104                         // 生成jpeg图片
105                         OutputStream out = new FileOutputStream("d:/ceshi.jpg");
106                         out.write(bytes);
107                         out.flush();
108                         out.close();
109                     } catch (Exception e) {
110                         e.printStackTrace();
111                     }
112                     // request.setAttribute(name, value);
113                 }else {
114                     // 对传入的非 简单的字符串进行处理 ,比如说二进制的 图片,电影这些
115                     /**
116                      * 以下三步,主要获取 上传文件的名字
117                      */
118                     // 获取路径名
119                     String value = item.getName();
120                     // 索引到最后一个反斜杠
121                     int start = value.lastIndexOf("\\");
122                     // 截取 上传文件的 字符串名字,加1是 去掉反斜杠,
123                     String filename = value.substring(start + 1);
124                     // 将当前时间戳 作为的文件名
125                     String newfilename = Long.toString(new Date().getTime())
126                             + filename.substring(filename.indexOf('.'));
127                     request.setAttribute(name, newfilename);
128 
129                     // 真正写到磁盘上
130                     // 它抛出的异常 用exception 捕捉
131 
132                     // item.write( new File(path,filename) );//第三方提供的
133 
134                     // 手动写的
135                     OutputStream out = new FileOutputStream(new File(path,
136                             newfilename));
137 
138                     InputStream in = item.getInputStream();
139 
140                     int length = 0;
141                     byte[] buf = new byte[1024];
142 
143                     System.out.println("获取上传文件的总共的容量:" + item.getSize());
144 
145                     // in.read(buf) 每次读到的数据存放在 buf 数组中
146                     while ((length = in.read(buf)) != -1) {
147                         // 在 buf 数组中 取出数据 写到 (输出流)磁盘上
148                         out.write(buf, 0, length);
149                     }
150                     in.close();
151                     out.close();
152                 }
153             }
154 
155         } catch (FileUploadException e) {
156             // TODO Auto-generated catch block
157             e.printStackTrace();
158         } catch (Exception e) {
159             // TODO Auto-generated catch block
160             e.printStackTrace();
161         }
162     }
163 }

 

posted @ 2016-04-27 10:43  幸福流浪  阅读(18945)  评论(0编辑  收藏  举报