1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 介绍HTML5+Canvas调用手机拍照功能实现图片上传(下篇)

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

时间:2023-11-14 13:57:44

相关推荐

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

web前端|H5教程

HTML5,Canvas,图片上传

web前端-H5教程

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

带报名功能的竞赛网站源码,ubuntu安装解压软件,爬虫宠物螳螂饲养,php 获取一个月前的日期,蜘蛛seo 运营lzw

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

教学网站 源码 php,ubuntu如何传送文件,爬虫快速入门教学,unhtml php,美食seo文章lzw

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

怎么给源码加壳,ubuntu 进程自启动,tomcat启动很慢的原因,爬虫写股票,无限流php,巴南抖客seo获客系统lzw

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

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。