全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

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


# HTML5  # Canvas  # 手机拍照  # 图片上传  # Javascript保存网页为图片借助于html2canvas库实现  # javascript结合canvas实现图片旋转效果  # JavaScript+html5 canvas实现图片破碎重组动画特效  # HTML5+Canvas调用手机拍照功能实现图片上传(上)  # 用canvas 实现个图片三角化(LOW POLY)效果  # HTML5 canvas 9绘制图片实例详解  # Canvas + JavaScript 制作图片粒子效果  # canvas实现图片根据滑块放大缩小效果  # canvas压缩图片转换成base64格式输出文件流  # 一步步教你利用Canvas对图片进行处理  # 上传  # 自己的  # 不存在  # 夹中  # 是否存在  # 文件上传  # 判断是否  # 好了  # 说了  # 这就是  # 不多  # 点此  # 不需  # 这篇  # 上一篇  # 涉及到  # 讲到  # 数据库中 


相关文章: Python lxml的etree和ElementTree有什么区别  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  如何快速生成ASP一键建站模板并优化安全性?  建站之星如何取消后台验证码生成?  建站之星代理如何优化在线客服效率?  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  免费网站制作appp,免费制作app哪个平台好?  建站之星免费版是否永久可用?  C#如何使用XPathNavigator高效查询XML  如何获取免费开源的自助建站系统源码?  安云自助建站系统如何快速提升SEO排名?  建站10G流量真的够用吗?如何应对访问高峰?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  常州企业建站如何选择最佳模板?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  如何通过VPS搭建网站快速盈利?  宝塔建站教程:一键部署配置流程与SEO优化实战指南  ,制作一个手机app网站要多少钱?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  建站主机选择指南:服务器配置与SEO优化实战技巧  c# F# 的 MailboxProcessor 和 C# 的 Actor 模型  网站制作新手教程,新手建设一个网站需要注意些什么?  如何在局域网内绑定自建网站域名?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  淘宝制作网站有哪些,淘宝网官网主页?  如何通过主机屋免费建站教程十分钟搭建网站?  内部网站制作流程,如何建立公司内部网站?  微信小程序 五星评分(包括半颗星评分)实例代码  临沂网站制作公司有哪些,临沂第四中学官网?  建站之星安装模板失败:服务器环境不兼容?  Swift中循环语句中的转移语句 break 和 continue  制作国外网站的软件,国外有哪些比较优质的网站推荐?  建站之星如何通过成品分离优化网站效率?  建站之星ASP如何实现CMS高效搭建与安全管理?  交易网站制作流程,我想开通一个网站,注册一个交易网址,需要那些手续?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  如何快速上传建站程序避免常见错误?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  建站之星安装失败:服务器环境不兼容?  如何在宝塔面板中修改默认建站目录?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  制作网站的基本流程,设计网站的软件是什么?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何用PHP快速搭建CMS系统?  宝塔建站助手安装配置与建站模板使用全流程解析  建站DNS解析失败?如何正确配置域名服务器?  制作旅游网站html,怎样注册旅游网站?  制作网页的网站有哪些,电脑上怎么做网页?  宝盒自助建站智能生成技巧:SEO优化与关键词设置指南  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。