溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringMVC+Ajax如何實(shí)現(xiàn)文件批量上傳和下載功能

發(fā)布時(shí)間:2021-05-18 12:53:05 來(lái)源:億速云 閱讀:345 作者:小新 欄目:web開(kāi)發(fā)

小編給大家分享一下SpringMVC+Ajax如何實(shí)現(xiàn)文件批量上傳和下載功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

上傳form:

<form id="uploadfiles" enctype="multipart/form-data">
    <input type="file" multiple="multiple" id="file_upload" name="file_upload" /> 
    <input type="button" value="上傳" onclick="upload()" />
</form>

上傳Ajax:

<script type="text/javascript">
/*
 * 上傳文件
 */
function upload(){
  var formData = new FormData($( "#uploadfiles" )[0]);
   $.ajax({
      type: "post",
      url: "./path/upload",
      dataType: "json",
      data: formData,
      /**  
       *必須false才會(huì)自動(dòng)加上正確的Content-Type  
       */ 
      contentType : false, 
      /**  
       * 必須false才會(huì)避開(kāi)jQuery對(duì) formdata 的默認(rèn)處理  
       * XMLHttpRequest會(huì)對(duì) formdata 進(jìn)行正確的處理  
       */ 
      processData : false,
      success: function(data){//從后端返回?cái)?shù)據(jù)進(jìn)行處理
       if(data){
         alert("上傳成功!");
       }else{
         alert("上傳失?。?quot;);
       }
      },
      error: function(err) {//提交出錯(cuò)
        $("#msg").html(JSON.stringify(err));//打出響應(yīng)信息
        alert("服務(wù)器無(wú)響應(yīng)");
       }
     });
}
</script>

spring.xml配置加上:

<!-- 配置文件上傳 -->
  <bean id="multipartResolver"
    class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- 默認(rèn)編碼 -->
    <property name="defaultEncoding" value="utf-8" />
    <!-- 文件大小最大值 -->
    <property name="maxUploadSize" value="10485760000" />
    <!-- 內(nèi)存中的最大值 -->
    <property name="maxInMemorySize" value="40960" />
  </bean>
controller:
/*
   * 上傳多個(gè)文件
   */
  @RequestMapping(value = "/upload", produces = "application/json;charset=UTF-8")
  public @ResponseBody
  boolean uploadFiles(@RequestParam("file_upload") MultipartFile [] files) {
    boolean result = false;
    String realPath;
    for(int i=0;i<files.length;i++){
      if (!files[i].isEmpty()) { 
          String uniqueName=files[i].getOriginalFilename();//得到文件名
          realPath="E:"+File.separator+uniqueName;//文件上傳的路徑這里為E盤
          files[i].transferTo(new File(realPath));  // 轉(zhuǎn)存文件
          result = true;      
        } catch (Exception e) { 
          e.printStackTrace(); 
        } 
      }
    }
    return result;
  }

下載的jsp頁(yè)面代碼根據(jù)需求不同自己設(shè)計(jì),這里給出controller代碼:

/*
   * 下載多個(gè)文件
   */
  @RequestMapping(value = "/download")
  public void downloadFiles(HttpServletResponse response) {
    String str= request.getParameter("rows");//下載文件信息,包括文件名、存儲(chǔ)路徑等
    JSONArray path=(JSONArray) JSONArray.parse(request.getParameter("rows"));
    Path paths[]=new Path[path.size()];
    paths = JSONArray.parseArray(str, Path.class).toArray(paths);
    String uri = "d:"+ File.separator + "mldn.zip";//臨時(shí)文件存儲(chǔ)路徑
    File zipFile = new File(uri) ;  // 定義壓縮文件名稱 
    ZipOutputStream zipOut = null;// 聲明壓縮流對(duì)象 
    InputStream input = null;
    //將要壓縮的文件加入到壓縮輸出流中
    try {
      zipOut = new ZipOutputStream(new FileOutputStream(zipFile));
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    }
    for(int i = 0;i<paths.length;i++){
      File file = new File(paths[i].getUri()+File.separator+paths[i].getFilename());
      try {
        input = new FileInputStream(file) ;// 定義文件的輸入流 
        zipOut.putNextEntry(new ZipEntry(file.getName())) ; // 設(shè)置ZipEntry對(duì)象 
      } catch (Exception e) {
        e.printStackTrace();
      } 
    }
    //將文件寫(xiě)入到壓縮文件中
    int temp = 0 ; 
    try {
      while((temp=input.read())!=-1){ // 讀取內(nèi)容 
        zipOut.write(temp) ;  // 寫(xiě)到壓縮文件中 
      }
    } catch (IOException e) {
      e.printStackTrace();
    }finally{ 
      try {
        input.close() ;
        zipOut.close() ; 
      } catch (IOException e) {
        e.printStackTrace();
      } 
    }
    try {
      // 以流的形式下載文件。
      BufferedInputStream fis = new BufferedInputStream(new FileInputStream(zipFile));
      byte[] buffer = new byte[fis.available()];
      fis.read(buffer);
      fis.close();
      // 清空response
      response.reset();
      OutputStream toClient = new BufferedOutputStream(response.getOutputStream());
      response.setContentType("application/x-msdownload;"); 
      response.setHeader("Content-Disposition", "attachment;filename=" + zipFile.getName());
      toClient.write(buffer);
      toClient.flush();
      toClient.close();
      zipFile.delete();    //將生成的服務(wù)器端文件刪除
    } 
    catch (IOException ex) {
      ex.printStackTrace();
    }  
  }

將多個(gè)文件打成一個(gè)壓縮包下載,然后將生成的臨時(shí)壓縮文件刪除。

下載頁(yè)面如果用Ajax提交請(qǐng)求的話要注意:ajax函數(shù)的返回類型只有xml、text、json、html等類型,沒(méi)有“流”類型,所以我們要實(shí)現(xiàn)ajax下載,不能夠使用相應(yīng)的ajax函數(shù)進(jìn)行文件下載。但可以用js生成一個(gè)form,用這個(gè)form提交參數(shù),并返回“流”類型的數(shù)據(jù)。

例子:

function download(){
    var form=$("<form>");//定義一個(gè)form表單
    form.attr("style","display:none");
    form.attr("target","");
    form.attr("method","post");
    form.attr("action","./path/download");//請(qǐng)求url
    var input1=$("<input>");
    input1.attr("type","hidden");
    input1.attr("name","rows");//設(shè)置屬性的名字
    input1.attr("value",“test”);//設(shè)置屬性的值
    $("body").append(form);//將表單放置在web中
    form.append(input1);
    form.submit();//表單提交       
              }

以上是“SpringMVC+Ajax如何實(shí)現(xiàn)文件批量上傳和下載功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI