站長資訊網
        最全最豐富的資訊網站

        介紹HTML5+Canvas調用手機拍照功能實現圖片上傳(下篇)

        這篇文章主要為大家詳細介紹了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;     }

        需要學習h5的同學請關注php中文網h5視頻教程,眾多h5在線視頻教程可以免費觀看!

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产成人精品无码播放| 精品无人区麻豆乱码1区2区| 国产精品无码一区二区三级| 国产精品无码DVD在线观看| 精品一区二区三区在线成人| 日韩经典精品无码一区| 亚洲国产精品成| 国产精品国产三级国产AV主播| 亚洲无码日韩精品第一页| Xx性欧美肥妇精品久久久久久| 国产精品露脸国语对白| 亚洲精品亚洲人成人网| 久久人人爽人人精品视频| 精品第一国产综合精品蜜芽| 国产A级毛片久久久精品毛片| 亚洲av无码国产精品色在线看不卡| 国产成人无码精品久久久免费 | 久久久久国产精品嫩草影院| 欧美国产日韩精品| 国产精品麻豆高清在线观看| 99久久精品国产高清一区二区 | 精品无码综合一区| 国产成人无码精品久久久久免费 | 国产办公室秘书无码精品99| 精品性影院一区二区三区内射| 无码精品国产一区二区三区免费 | 久久无码精品一区二区三区| www.日韩精品| 97精品国产97久久久久久免费| 国内精品免费在线观看| 国产成人精品久久二区二区| 国产AV国片精品有毛| 99精品热这里只有精品| 99久久精品国产麻豆| 国产短视频精品一区二区三区| 国产精品对白刺激久久久| 国产精品毛片一区二区三区| 2021国产成人精品国产| 久久er国产精品免费观看2| 桃花岛精品亚洲国产成人| 国产成人精品亚洲精品|