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

溫馨提示×

溫馨提示×

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

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

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

诸城市| 犍为县| 石景山区| 金溪县| 敖汉旗| 宣化县| 玛多县| 商河县| 江城| 鹤山市| 西藏| 平阳县| 广南县| 松江区| 增城市| 嘉黎县| 彩票| 罗城| 武山县| 佳木斯市| 星子县| 开封县| 烟台市| 启东市| 兴安盟| 锡林郭勒盟| 湟源县| 赫章县| 喜德县| 南城县| 城步| 临澧县| 固镇县| 崇文区| 纳雍县| 绥滨县| 克拉玛依市| 揭西县| 昆山市| 曲靖市| 绥中县|