亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

spring mvc+localResizeIMG實現HTML5端圖片壓縮上傳

發布時間:2020-10-13 07:17:06 來源:腳本之家 閱讀:173 作者:Mr_Smile2014 欄目:編程語言

最近在做一個移動端HTML5的應用,使用到了上傳功能,起初使用傳統的上傳方式上傳手機拍照的照片,由于手機拍照出來的照片一般都是好幾MB,所以上傳速度是非常慢的。

在網上找了很久找到了localResizeIMG壓縮框架,感覺非常的實用,所以在此分享給大家。

第一步:下載localResizeIMG
localResizeIMG放在github中的,地址是:https://github.com/think2011/localResizeIMG。

第二步:在web工程中導入localResizeIMG相關js
解壓localResizeIMG壓縮吧,把目錄中的dist文件夾拷貝到工程中,我的是放在js目錄下。
然后在自己的js中導入jquery和localResizeIMG的js。如:

<script src="<c:url value="/js/JQuery/jquery-1.10.0.min.js"/>"></script> 
<script type="text/javascript" src="<c:url value="/js/lrz/dist/lrz.bundle.js"/>"></script> 

第三步:在自己的上傳的input的file框加入onchange事件如下代碼
<input  type="file"  id="payfile" name="myfile" onchange="fileChange(this)" />

在fileChange方法中實現代碼的壓縮和對壓縮后生成的base64異步傳到后臺

function fileChange(that){ 
  var filepath=$(that).val(); 
  if(filepath=="") 
  { 
   return; 
  } 
  var extStart=filepath.lastIndexOf("."); 
  var ext=filepath.substring(extStart,filepath.length).toUpperCase(); 
  if(".jpg|.png|.bmp|.jpeg".toUpperCase().indexOf(ext.toUpperCase())==-1){ 
   alert("只允許上傳jpg、png、bmp、jpeg格式的圖片"); 
   return false; 
  } 
  //以圖片寬度為800進行壓縮 
 lrz(that.files[0], { 
   width: 800 
  }) 
 .then(function (rst) { 
   //壓縮后異步上傳 
   $.ajax({ 
   url : "<%=request.getContextPath()%>/common/fileUploadPicture", 
   type: "POST", 
   data : { 
    imgdata:rst.base64//壓縮后的base值 
   }, 
   dataType:"json", 
   cache:false, 
   async:false, 
   success : function(data) { 
   if(data.success) 
    { 
     alert(data.message);///data.message為上傳成功后的文件路徑 
    }else{ 
     alert(data.message);///data.message為上傳失敗原因 
    } 
        
      }, 
  error : function(){ 
    alert("上傳失敗"); 
      } 
     }); 
   }); 
} 

第四步:spring mvc controller 后臺接收base值并解析并保存文件

import sun.misc.BASE64Decoder;//導入的base64的類 
/** 
  * 文件上傳 
  */ 
 @ResponseBody 
 @RequestMapping("common/fileUploadPicture") 
 public Object fileUploadPicture(String imgdata, HttpServletRequest request) { 
  LOGGER.info("[文件上傳(fileUploadPicture)][params:imgdata=" + imgdata + "]"); 
   BASE64Decoder decoder = new BASE64Decoder(); 
  try { 
   String basePath = request.getRealPath("/upload_files"); 
   string imgPath=basePath+"/test.jpg"; 
   // new一個文件對象用來保存圖片,默認保存當前工程根目錄 
   File imageFile = new File(imgPath); 
   // 創建輸出流 
   FileOutputStream outputStream = new FileOutputStream(imageFile); 
   // 獲得一個圖片文件流,我這里是從flex中傳過來的 
   byte[] result = decoder.decodeBuffer(imgdata.split(",")[1]);//解碼 
   for (int i = 0; i < result.length; ++i) { 
    if (result[i] < 0) {// 調整異常數據 
    result[i] += 256; 
   } 
  } 
   outputStream.write(result); 
 
   return new Result(true, imgPath); 
  } catch (AppException e1) { 
   LOGGER.error("[文件上傳(fileUpload)-fastdfs][errors:" + e1 + "]"); 
   return new Result(false, "文件上傳失敗"); 
  } catch (Exception e) { 
   LOGGER.error("[文件上傳(fileUpload)][errors:" + e + "]"); 
   return new Result(false, "文件上傳失敗"); 
  }finally{ 
  outputStream.flush(); 
  outputStream.close(); 
   
  } 
 } 

Result類:

import java.io.Serializable; 
 
public class Result implements Serializable{ 
 private static final long serialVersionUID = 1L; 
 private boolean success; 
 private String message; 
 
 public Result() { 
  success = true; 
 } 
 
 public Result(boolean success, String message) { 
  this.success = success; 
  this.message = message; 
 } 
 
 public boolean isSuccess() { 
  return success; 
 } 
 
 public void setSuccess(boolean success) { 
  this.success = success; 
 } 
 
 public String getMessage() { 
  return message; 
 } 
 
 public void setMessage(String message) { 
  this.message = message; 
 } 
 
 @Override 
 public String toString() { 
  return "Result [success=" + success + ", message=" + message + "]"; 
 } 
 
} 

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

向AI問一下細節

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

AI

高尔夫| 金秀| 施甸县| 长宁县| 开平市| 洛川县| 黔东| 板桥市| 广安市| 广德县| 张家川| 名山县| 上高县| 郸城县| 西吉县| 奉化市| 巴中市| 孝义市| 青神县| 延边| 福清市| 马鞍山市| 雷州市| 绥宁县| 巫溪县| 德江县| 古丈县| 旺苍县| 资兴市| 北海市| 阜南县| 五寨县| 科技| 边坝县| 晋宁县| 赫章县| 肥东县| 秦皇岛市| 阿勒泰市| 揭东县| 务川|