91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-08-31 05:25:51 來源:腳本之家 閱讀:215 作者:鬼腳飛 欄目:web開發

上一篇只講到前臺操作,這篇專門涉及到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; 
  } 

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

上饶市| 德惠市| 苗栗县| 来安县| 瑞安市| 梁河县| 安宁市| 乌拉特前旗| 阿鲁科尔沁旗| 调兵山市| 多伦县| 鄄城县| 扎囊县| 基隆市| 台湾省| 依安县| 普兰店市| 永城市| 青海省| 互助| 乌拉特中旗| 肇东市| 黔南| 贵定县| 贺州市| 红安县| 安远县| 新巴尔虎右旗| 荔浦县| 京山县| 宣化县| 芒康县| 宝清县| 武鸣县| 宁河县| 潢川县| 武邑县| 常德市| 福贡县| 磴口县| 集贤县|