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

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

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

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

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

1、前台js代码

rush: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代码

rush: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.getP<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>meter("cust_tax_code"); 
String phoneNum = request.getP<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>meter("phoneNum"); 
String licenceName = request.getP<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>meter("licenceName"); 

String fileData = request.getP<a href="https://www.jb51.cc/tag/ara/" target="_blank" class="keywords">ara</a>meter("fileData");//Base64编码过的<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>数据信息,对字节数组字符串进行Base64解码 
String imgPath = uploadFile(fileData,liceneName);//进行<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a><a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>操作,<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>到服务器中存放(这里是<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>到服务器项目<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>夹中存到) 

boolean result = false;//最终<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>成功与否的标志 

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);//保存路径 

//判断<a href="https://www.jb51.cc/tag/shujuku/" target="_blank" class="keywords">数据库</a>中的路径是否存在,并且<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>夹中的<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>是否存在(判断是否<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>成功的标志) 
boolean is_success = isSucces<a href="https://www.jb51.cc/tag/supl/" target="_blank" class="keywords">supl</a>oad(licenceName,cust_tax_code,phoneNum); 
if(save_flag && is_success){ 
  result = true; 
} 

//如果证件<a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a>成功,则记录到记录表中 
if(result){ 
  StateRecordInfo record = new StateRecordInfo(); 
  record.setCust_tax_code(cust_tax_code); 
  record.setPhonenum(phoneNum); 
  record.setState_id(state_id); 

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

Sy<a href="https://www.jb51.cc/tag/stem/" target="_blank" class="keywords">stem</a>.out.println("===result:"+result); 
PrintWriter pw = response.getWriter(); 
pw.print(result); 
pw.close(); 

}

rush:java;"> /** * 文件上传 * @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("====<a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>保存的位置:"+imgPath); 

//使用BASE64对<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>数据进行解码操作 
BASE64Decoder decoder = new BASE64Decoder(); 
try { 
  //通过Base64解密,将<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>数据解密成字节数组 
  byte[] bytes = decoder.decodeBuffer(fileData); 
  //构造字节数组输入流 
  ByteArrayInputStream bais = new ByteArrayInputStream(bytes); 
  //读取输入流的数据 
  BufferedImage bi = ImageIO.read(bais); 
  //将数据信息写进<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a><a href="https://www.jb51.cc/tag/wenjian/" target="_blank" class="keywords">文件</a>中 
  ImageIO.write(bi,"jpg",f);// 不管<a href="https://www.jb51.cc/tag/shuchu/" target="_blank" class="keywords">输出</a>什么格式<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>,此处不需改动 
  bais.close(); 
} catch (IOException e) { 
  log.error("e:{}",e); 
} 
return imgPath; 

}

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调用手机拍照功能实现图片上传的全部实现过程,总感觉自己的思路有些混乱,嗯,慢慢进步吧!

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

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面