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


本文摘自PHP中文网,作者怪我咯,侵删。

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

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

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

HTML5+Canvas调用手机拍照功能实现图片上传功能(图文详解上篇)

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;

  }


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

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

相关阅读 >>

HTML5和css3扁平化风格博客教程的资源分享

video标签无法播放mp4问题在HTML5中的解决办法

css实现等高布局的三种方式(代码示例)

HTML5能干什么?详解HTML5的功能

HTML5游戏开发引擎-初识createjs的详解(图文)

HTML5不常用标签可以怎么使用?

h5的新增标签和废弃标签

jquery方法的总结(附示例)

HTML5 canvas实现画未闭合的路径及渐变色的填充方法

HTML5 canvas api中drawimage()方法的使用代码实例分享(图)

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




打赏

取消

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

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

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

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

评论

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