最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小OO 时间:2020-11-27 15:09:44
文档

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

上一篇只讲到前台操作,这篇专门涉及到Java后台处理,前台通过Ajax提交将Base64编码过的图片数据信息传到Java后台,然后Java这边进行接收处理,通过对图片数据信息进行Base64解码,之后使用流将图片数据信息上传至服务器进行保存,并且将图片的路径地址存进数据库。大家可以点此链接查看前台本地压缩上传的处理。HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(上)。ok,废话不多说了,直接贴代码吧。1、前台js代码。2、后台Java代码。
推荐度:
导读上一篇只讲到前台操作,这篇专门涉及到Java后台处理,前台通过Ajax提交将Base64编码过的图片数据信息传到Java后台,然后Java这边进行接收处理,通过对图片数据信息进行Base64解码,之后使用流将图片数据信息上传至服务器进行保存,并且将图片的路径地址存进数据库。大家可以点此链接查看前台本地压缩上传的处理。HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(上)。ok,废话不多说了,直接贴代码吧。1、前台js代码。2、后台Java代码。


这篇文章主要为大家详细介绍了HTML5+Canvas调用手机拍照功能实现图片上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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

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

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

1、前台js代码:

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; 
 }

需要学习h5的同学请关注Gxl网h5视频教程,众多h5在线视频教程可以免费观看!

文档

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

上一篇只讲到前台操作,这篇专门涉及到Java后台处理,前台通过Ajax提交将Base64编码过的图片数据信息传到Java后台,然后Java这边进行接收处理,通过对图片数据信息进行Base64解码,之后使用流将图片数据信息上传至服务器进行保存,并且将图片的路径地址存进数据库。大家可以点此链接查看前台本地压缩上传的处理。HTML5+Canvas+jQuery调用手机拍照功能实现图片上传(上)。ok,废话不多说了,直接贴代码吧。1、前台js代码。2、后台Java代码。
推荐度:
标签: 手机 开发 图图片
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top