HTML5+Canvas调用手机拍照功能实现图片上传(下)

上一篇只讲到前台操作,这篇专门涉及到Java后台处理,前台通过Ajax提交将Base64编码过的图片数据信息传到Java后台,然后Java这边进行接收处理,通过对图片数据信息进行Base64解码,之后使用流将图片数据信息上传至服务器进行保存,并且将图片的路径地址存进数据库。

大家可以点此链接查看前台本地压缩上传的处理:

HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(上)

ok,废话不多说了,直接贴代码吧。

1、前台js代码:

$.ajax({
        async:false,//是否异步
        cache:false,//是否使用缓存
        type: "POST",
        data:{fileData:fileData,licenceName:licenceName,cust_tax_code:cust_tax_code,phoneNum:phoneNum,state_id:state_id},
        dataType: "json",
        timeout: 1000,
        contentType : 'application/x-www-form-urlencoded; charset=utf-8',
        url: $('#ctx').val()+"CustomerCheckServlet?action=uploadLicence",
        success: function(result){
          console.log(result);
          if(result == true){
            alert('Success Upload~~~');
          }else if(result == false){
            alert('Error Upload~~~');
          }
        },
        error: function(){
          alert("Error Linking~");
        }
      }); 

2、后台Java代码

/**
   * 证件上传
   * @param request
   * @param response
   * @throws IOException
   */
  public void uploadLicence(HttpServletRequest request,HttpServletResponse response) throws IOException{
    log.info("=====================uploadLicence");
    df = new SimpleDateFormat("yyyy-MM-dd"); 

    String cust_tax_code = request.getParameter("cust_tax_code");
    String phoneNum = request.getParameter("phoneNum");
    String licenceName = request.getParameter("licenceName"); 

    String fileData = request.getParameter("fileData");//Base64编码过的图片数据信息,对字节数组字符串进行Base64解码
    String imgPath = uploadFile(fileData,liceneName);//进行文件上传操作,上传到服务器中存放(这里是上传到服务器项目文件夹中存到) 

    boolean result = false;//最终上传成功与否的标志 

    custCheckInfo = new CustomerCheckInfo();
    custCheckInfo.setCust_tax_code(cust_tax_code);
    custCheckInfo.setPhonenum(phoneNum);
    custCheckInfo.setUpdate_time(df.format(new Date())); 

    boolean save_flag = customerService.saveRegistCertInfo(custCheckInfo);//保存路径 

    //判断数据库中的路径是否存在,并且文件夹中的文件是否存在(判断是否上传成功的标志)
    boolean is_success = isSuccessUpload(licenceName, cust_tax_code, phoneNum);
    if(save_flag && is_success){
      result = true;
    } 

    //如果证件上传成功,则记录到记录表中
    if(result){
      StateRecordInfo record = new StateRecordInfo();
      record.setCust_tax_code(cust_tax_code);
      record.setPhonenum(phoneNum);
      record.setState_id(state_id); 

      saveStateRecord(record);//执行状态保存操作
    } 

    System.out.println("===result:"+result);
    PrintWriter pw = response.getWriter();
    pw.print(result);
    pw.close();
  }
/**
   * 文件上传
   * @param fileData
   * @param fileName
   * @return
   */
  public String uploadFile(String fileData,String fileName){
    //在自己的项目中构造出一个用于存放用户照片的文件夹
    String imgPath = this.getServletContext().getRealPath("/uploads/");
    //如果此文件夹不存在则创建一个
    File f = new File(imgPath);
    if(!f.exists()){
      f.mkdir();
    }
    //拼接文件名称,不存在就创建
    imgPath = imgPath + "/" + fileName + ".jpg";
    f = new File(imgPath);
    if(!f.exists()){
      f.mkdir();
    } 

    log.info("====文件保存的位置:"+imgPath); 

    //使用BASE64对图片文件数据进行解码操作
    BASE64Decoder decoder = new BASE64Decoder();
    try {
      //通过Base64解密,将图片数据解密成字节数组
      byte[] bytes = decoder.decodeBuffer(fileData);
      //构造字节数组输入流
      ByteArrayInputStream bais = new ByteArrayInputStream(bytes);
      //读取输入流的数据
      BufferedImage bi = ImageIO.read(bais);
      //将数据信息写进图片文件中
      ImageIO.write(bi, "jpg", f);// 不管输出什么格式图片,此处不需改动
      bais.close();
    } catch (IOException e) {
      log.error("e:{}",e);
    }
    return imgPath;
  } 
/**
   * 判断是否成功上传
   * @return
   */
  public boolean isSuccessUpload(String licenceName,String cust_tax_code,String phonenum){
    boolean flag = false;
    String licencePath = "";//证件图片上传成功之后保存的路径 

    custCheckInfo = customerService.getCustomerCheckInfo(cust_tax_code, phonenum);
    licencePath = custCheckInfo.getTax_regist_cert(); 

    //判断证件路径不为空并且在上传存放的文件夹中存在,就表明以上传成功
    File f = new File(licencePath);
    if(licencePath.length() >0 && f.exists()){
      flag = true;
    }
    return flag;
  } 

好了,到这里就全部结束了,这就是HTML5+jQuery+Canvas调用手机拍照功能实现图片上传的全部实现过程,总感觉自己的思路有些混乱,嗯,慢慢进步吧!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Javascript保存网页为图片借助于html2canvas库实现

    第一步,把网页保存为Canvas画布,借助于html2canvas库,http://html2canvas.hertzen.com/ html2canvas(document.getElementById("id1"), { onrendered: function(canvas) { document.getElementById("id2").appendChild(canvas);//生成画布后如何处理,当然可以在新标签打开,在浮层展示等等 }, canvas

  • canvas压缩图片转换成base64格式输出文件流

    昨天研究了一下canvas压缩图片的方法,上传上来给大家分享一下 <!--调用canvas方法--> <canvas id="canvas"></canvas> <!--压缩后的图片路劲--> <img src="" class="preview"> <img src="" class="preview"> <!--原图压缩--&

  • HTML5 canvas 9绘制图片实例详解

    绘制图片 Var image=new Image(); image.src=" http://img4.duitang.com/uploads/item/201406/25/20140625182321_4MTau.thumb.700_0.jpeg"; image.onload=function(){} Context.drawImage(image,x,y); Context.drawImage(image,x,y,w,h); Context.drawIamge(image,sx,s

  • JavaScript+html5 canvas实现图片破碎重组动画特效

    也许你见过HTML5图片破碎动画特效,实现的原理也挺简单的.但是你应该没有见过视频也可以破碎重组,这个HTML5动画就是利用Canvas的相关特性,实现了点击鼠标让视频破碎重组的效果.在视频区域点击鼠标,即可让该区域的视频破碎,让后经过一段时间后,破碎的区域又可以重组还原,视觉效果非常棒. HTML代码 <div style="display:none"> <video id="sourcevid" autoplay="true"

  • HTML5+Canvas调用手机拍照功能实现图片上传(上)

    因为最近一段时间,一直在弄微信项目,其中涉及到了证件上传的功能,刚开始的时候一点头绪都没有,上网查了很多资料,QQ群里面也问了不少人,很多人说如果是app程序,可以申请系统权限,然后再去调用系统底层的东西,但是微信是在浏览器里面操作的,我们自定义的页面也是通过微信内置浏览器打开的,而且微信浏览器在内部进行了很多特殊处理,屏蔽了很多东西,所以要在页面调用拍照功能或者是打开手机系统的图库目录是不可能的,当然,这些都只是大伙儿理论上的猜测而已,而在我查了两天的资料之后,发现这个问题原来是可以解决的,而

  • javascript结合canvas实现图片旋转效果

    我们在微博上可以对图片进行向左转向右转等旋转操作,让用户可以从不同的视角欣赏图片效果.本文将结合实例为您讲解如何使用Javascript结合相关技术来实现图片的旋转效果.我们使用HTML5的canvas标签可对图片进行旋转操作,对于ie6,7,8不支持HTML5的浏览器,我们使用IE特有的滤镜效果来实现图片旋转. HTML 我们在页面中放置一张图片,在图片的上方放置两个按钮,通过onclick事件调用rotate()函数来控制图片向左向右旋转. <div id="tool">

  • 一步步教你利用Canvas对图片进行处理

    前言 Canvas,中文译为"画布",HTML5中新增了<canvas>元素,可以结合JavaScript动态地在画布中绘制图形. 今天,我们不讲Canvas的图形绘制,而是讲如何对图片进行处理,话不多说了,来一起看看详细的介绍吧. 大概流程非常简单,主要分为以下三个步骤: Canvas图片处理 是的,就像把大象装进冰箱一样简单,哈哈. 一.主要API 整个流程中所用到的主要Canvas API有: 绘制图像: drawImage() 获取图像数据: getImageDat

  • 用canvas 实现个图片三角化(LOW POLY)效果

    之前无意中看到Ovilia 用threejs做了个LOW POLY,也就是图片平面三角化的效果,觉得很惊艳,然后就自己花了点时间尝试了一下. 我是没怎么用过threejs,所以就直接用canvas的2d绘图API来做,因为感觉似乎这效果也用不上threejs. 直接上demo先:http://whxaxes.github.io/canvas-test/src/Funny-demo/lowpoly/index.html(也可以在移动端看,不过因为计算量比较大,移动设备计算起来会比PC要多花些时间.

  • Canvas + JavaScript 制作图片粒子效果

    首先看一下源图和转换成粒子效果的对比图: 左侧图片为源图,右侧图片为粒子效果图.该效果是在Canvas画布上制作的.将图片制作成粒子效果相对而言是比较简单的.重点了解两个知识点即可 1:图片是通过image对象形式绘制在画布上的,然后使用Canvas的getImageData接口,获取图像的像素信息. var imageData=ctx.getImageData(x, y, width, height); 参数说明:x,y为画布上的x和y坐标 width,height为获取指定区域图像的信息 返

  • canvas实现图片根据滑块放大缩小效果

    效果图: 图(1) 原始图 图(2) 缩小后 图(3) 放大后 代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title></title> <style type="text/css"> #canvas1{ box-shadow: 3px 3px 10px black; } </style> &

随机推荐