站長資訊網(wǎng)
        最全最豐富的資訊網(wǎng)站

        HTML5+Canvas調(diào)用手機拍照功能實現(xiàn)圖片上傳功能(圖文詳解下篇)

        這篇文章主要為大家詳細介紹了HTML5+Canvas調(diào)用手機拍照功能實現(xiàn)圖片上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下

        上一篇只講到前臺操作,這篇專門涉及到Java后臺處理,前臺通過Ajax提交將Base64編碼過的圖片數(shù)據(jù)信息傳到Java后臺,然后Java這邊進行接收處理,通過對圖片數(shù)據(jù)信息進行Base64解碼,之后使用流將圖片數(shù)據(jù)信息上傳至服務(wù)器進行保存,并且將圖片的路徑地址存進數(shù)據(jù)庫。

        大家可以點此鏈接查看前臺本地壓縮上傳的處理:

        HTML5+Canvas調(diào)用手機拍照功能實現(xiàn)圖片上傳功能(圖文詳解上篇)

        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編碼過的圖片數(shù)據(jù)信息,對字節(jié)數(shù)組字符串進行Base64解碼       String imgPath = uploadFile(fileData,liceneName);//進行文件上傳操作,上傳到服務(wù)器中存放(這里是上傳到服務(wù)器項目文件夾中存到)              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);//保存路徑              //判斷數(shù)據(jù)庫中的路徑是否存在,并且文件夾中的文件是否存在(判斷是否上傳成功的標志)       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);//執(zhí)行狀態(tài)保存操作       }              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){       //在自己的項目中構(gòu)造出一個用于存放用戶照片的文件夾       String imgPath = this.getServletContext().getRealPath("/uploads/");       //如果此文件夾不存在則創(chuàng)建一個       File f = new File(imgPath);       if(!f.exists()){         f.mkdir();       }       //拼接文件名稱,不存在就創(chuàng)建       imgPath = imgPath + "/" + fileName + ".jpg";       f = new File(imgPath);       if(!f.exists()){         f.mkdir();       }              log.info("====文件保存的位置:"+imgPath);              //使用BASE64對圖片文件數(shù)據(jù)進行解碼操作       BASE64Decoder decoder = new BASE64Decoder();       try {         //通過Base64解密,將圖片數(shù)據(jù)解密成字節(jié)數(shù)組         byte[] bytes = decoder.decodeBuffer(fileData);         //構(gòu)造字節(jié)數(shù)組輸入流         ByteArrayInputStream bais = new ByteArrayInputStream(bytes);         //讀取輸入流的數(shù)據(jù)         BufferedImage bi = ImageIO.read(bais);         //將數(shù)據(jù)信息寫進圖片文件中         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;     }

        好了,到這里就全部結(jié)束了,這就是HTML5+jQuery+Canvas調(diào)用手機拍照功能實現(xiàn)圖片上傳的全部實現(xiàn)過程,總感覺自己的思路有些混亂,嗯,慢慢進步吧!

        贊(0)
        分享到: 更多 (0)
        網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
        主站蜘蛛池模板: 精品国产美女福利到在线不卡| 99久久国产综合精品麻豆| 亚洲AV成人精品网站在线播放| 国产成人99久久亚洲综合精品| 精品无码AV一区二区三区不卡| 日本精品视频在线观看| 青青青国产精品国产精品久久久久| 欧洲成人午夜精品无码区久久| 国内精品久久久久久麻豆| 精品国产第1页| 久久精品人成免费| 亚洲午夜精品久久久久久浪潮| 国产区精品高清在线观看| 免费精品99久久国产综合精品| 国产精品视频一区二区三区四| 亚洲国产精品无码久久| 久久99精品九九九久久婷婷| 91午夜精品亚洲一区二区三区| A级精品国产片在线观看| 精品性影院一区二区三区内射 | 国产精品久久波多野结衣| 久久精品国产久精国产思思| 亚洲午夜国产精品无码 | 成人国产精品免费视频| 久久国产精品无码一区二区三区| 亚洲精品国产精品乱码不99| 自拍偷在线精品自拍偷无码专区| 亚洲国产精品成人一区| 香港三级精品三级在线专区 | 合区精品中文字幕| 免费精品精品国产欧美在线| 久久久精品国产Sm最大网站| 精品一区二区三区免费观看| 久久精品国产99国产精品| 青青草97国产精品免费观看| 欧美午夜精品一区二区三区91| 欧美日韩精品一区二区三区不卡 | 麻豆国产高清精品国在线| 免费看污污的网站欧美国产精品不卡在线观看 | 精品欧洲av无码一区二区 | 亚洲精品无码永久中文字幕|