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


本文摘自PHP中文网,作者零下一度,侵删。

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

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

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

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

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

1、前台js代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

$.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代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

/**

   * 证件上传

   * @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();

  }

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

/**

   * 文件上传

   * @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;

  }

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

/**

   * 判断是否成功上传

   * @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的同学请关注php中文网h5视频教程,众多h5在线视频教程可以免费观看!

以上就是介绍HTML5+Canvas调用手机拍照功能实现图片上传(下篇)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

HTML5实践-如何使用css3丰富图片样式的详解(二)

HTML5移动端手机网站开发流程

详解HTML5实现橡皮擦的擦除效果的示例代码(图)

HTML5需遵循怎样的6个设计原则?

HTML5-xmlhttprequest level 2概述详解

HTML5 canvas中放入图片和保存为图片的方法

HTML5与html区别是什么

h5拖放api进行拖放排序

HTML5+a*算法实现游戏寻路的代码分享

h5和c3怎样做出太阳系行星运转的动画效果

更多相关阅读请进入《HTML5》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...