亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

spring mvc+localResizeIMG實現(xiàn)HTML5端圖片壓縮上傳

 更新時間:2017年04月21日 15:45:22   作者:Mr_Smile2014  
這篇文章主要為大家詳細介紹了使用spring mvc+localResizeIMG實現(xiàn)HTML5端圖片壓縮上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

在網(wǎng)上找了很久找到了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" style="display:none;" onchange="fileChange(this)" />

在fileChange方法中實現(xiàn)代碼的壓縮和對壓縮后生成的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); 
   // 創(chuàng)建輸出流 
   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) {// 調(diào)整異常數(shù)據(jù) 
    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 + "]"; 
 } 
 
} 

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Java跳臺階實現(xiàn)思路和代碼

    Java跳臺階實現(xiàn)思路和代碼

    今天小編就為大家分享一篇關于Java跳臺階實現(xiàn)思路和代碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • mybatis-plus實現(xiàn)打印完整sql語句

    mybatis-plus實現(xiàn)打印完整sql語句

    這篇文章主要介紹了mybatis-plus實現(xiàn)打印完整sql語句方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Java8新特性之空指針異常的克星Optional類的實現(xiàn)

    Java8新特性之空指針異常的克星Optional類的實現(xiàn)

    這篇文章主要介紹了Java8新特性之空指針異常的克星Optional類的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • 詳解Java的MyBatis框架中SQL語句映射部分的編寫

    詳解Java的MyBatis框架中SQL語句映射部分的編寫

    這篇文章主要介紹了Java的MyBatis框架中SQL語句映射部分的編寫,文中分為resultMap和增刪查改實現(xiàn)兩個部分來講解,需要的朋友可以參考下
    2016-04-04
  • SpringCloud使用Zookeeper作為注冊中心

    SpringCloud使用Zookeeper作為注冊中心

    這篇文章主要介紹了SpringCloud如何使用Zookeeper作為注冊中心,幫助大家更好的理解和學習使用Zookeeper,感興趣的朋友可以了解下
    2021-04-04
  • SpringBoot整合Mybatis注解開發(fā)的實現(xiàn)代碼

    SpringBoot整合Mybatis注解開發(fā)的實現(xiàn)代碼

    這篇文章主要介紹了SpringBoot整合Mybatis注解開發(fā)的實現(xiàn)代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Java學習筆記之觀察者模式

    Java學習筆記之觀察者模式

    這篇文章主要為大家詳細介紹了Java學習筆記之觀察者模式的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • java 數(shù)據(jù)結(jié)構(gòu)與算法 (快速排序法)

    java 數(shù)據(jù)結(jié)構(gòu)與算法 (快速排序法)

    這篇文章主要介紹了java 數(shù)據(jù)結(jié)構(gòu)與算法(快速排序法),,快速排序法是實踐中的一種快速的排序算法,在c++或?qū)ava基本類型的排序中特別有用,下面我們一起進入文章學習更詳細的內(nèi)容吧,需要的朋友可以參考下
    2022-02-02
  • Java內(nèi)存泄漏問題處理方法經(jīng)驗總結(jié)

    Java內(nèi)存泄漏問題處理方法經(jīng)驗總結(jié)

    今天小編就為大家分享一篇關于Java內(nèi)存泄漏問題處理方法經(jīng)驗總結(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • Spring Mvc下實現(xiàn)以文件流方式下載文件的方法示例

    Spring Mvc下實現(xiàn)以文件流方式下載文件的方法示例

    這篇文章主要介紹了Spring Mvc下實現(xiàn)以文件流方式下載文件的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05

最新評論