亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

SpringMVC下實現Excel文件上傳下載

2024-07-14 08:40:08
字體:
來源:轉載
供稿:網友

在實際應用中,經常會遇到上傳Excel或者下載Excel的情況,比如導入數據、下載統計數據等等場景。針對這個問題,我寫了個基于SpringMVC的簡單上傳下載示例,其中Excel的處理使用Apache的POI組件。

主要依賴的包如下:

<dependency>    <groupId>commons-io</groupId>    <artifactId>commons-io</artifactId>    <version>2.4</version>   </dependency>   <dependency>    <groupId>commons-fileupload</groupId>    <artifactId>commons-fileupload</artifactId>    <version>1.3.1</version>   </dependency>   <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-web</artifactId>    <version>4.0.0.RELEASE</version>   </dependency>   <dependency>    <groupId>org.springframework</groupId>    <artifactId>spring-webmvc</artifactId>    <version>4.0.0.RELEASE</version>   </dependency>   <dependency>    <groupId>org.apache.poi</groupId>    <artifactId>poi</artifactId>    <version>3.10.1</version>   </dependency> 

相關處理類:

(一)Controller類

package com.research.spring.controller;  import java.io.IOException; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map;  import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.servlet.ModelAndView;  import com.research.spring.model.UserInfo; import com.research.spring.view.ExcelView;  @Controller @RequestMapping("/file") public class FileController {   /**   * Excel文件上傳處理   * @param file   * @return   */  @RequestMapping("/upload")  public ModelAndView uploadExcel(@RequestParam("file") MultipartFile file){   List<UserInfo> list = new ArrayList<UserInfo>();     //這里只處理文件名包括“用戶”的文件,模板使用下載模板   if( file.getOriginalFilename().contains("用戶") ){    try {     Workbook wb = new HSSFWorkbook(file.getInputStream());     Sheet sheet = wb.getSheetAt(0);     for( int i = 1; i <= sheet.getLastRowNum(); i++ ){      Row row = sheet.getRow(i);      UserInfo info = new UserInfo();      info.setUserName(row.getCell(0).getStringCellValue());      info.setPassword(row.getCell(1).getStringCellValue());      list.add(info);     }    } catch (IOException e) {     e.printStackTrace();    }   }   ModelAndView mav = new ModelAndView("content");   mav.addObject("content",list.toString());   return mav;  }    /**   * Excel文件下載處理   */  @RequestMapping("/download")  public ModelAndView downloanExcel(){   List<UserInfo> list = new ArrayList<UserInfo>();   UserInfo userInfo = new UserInfo();   userInfo.setPassword("0000");   userInfo.setUserName("sdfas");   list.add(userInfo);   list.add(userInfo);   list.add(userInfo);   list.add(userInfo);   Map<String,List<UserInfo>> map = new HashMap<String, List<UserInfo>>();   map.put("infoList", list);   ExcelView ve = new ExcelView();   return new ModelAndView(ve,map);  }  } 

(二)實體類

package com.research.spring.model;  public class UserInfo {   private String userName;    private String password;   public String getUserName() {   return userName;  }   public void setUserName(String userName) {   this.userName = userName;  }   public String getPassword() {   return password;  }   public void setPassword(String password) {   this.password = password;  }   @Override  public String toString() {   return "UserInfo [userName=" + userName + ", password=" + password     + "]";  }  } 

(三)View類

這個類在下載時用到,在Spring渲染頁面時使用自定義的View類進行Excel的相關處理。

package com.research.spring.view;  import java.io.OutputStream; import java.net.URLEncoder; import java.util.List; import java.util.Map;  import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse;  import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.springframework.web.servlet.view.document.AbstractExcelView;  import com.research.spring.model.UserInfo;  /**  * 下載Excel視圖  *  * @author wdmcygah  *  */ public class ExcelView extends AbstractExcelView {   @Override  protected void buildExcelDocument(Map<String, Object> model,    HSSFWorkbook workbook, HttpServletRequest request,    HttpServletResponse response) throws Exception {   @SuppressWarnings("unchecked")   List<UserInfo> list = (List<UserInfo>) model.get("infoList");   if (list != null && list.size() != 0) {    int len = list.size();    Sheet sheet = workbook.createSheet();    // 第一行文字說明    Row row = sheet.createRow(0);    Cell cell = row.createCell(0, Cell.CELL_TYPE_STRING);    cell.setCellValue("用戶名");    cell = row.createCell(1, Cell.CELL_TYPE_STRING);    cell.setCellValue("密碼");     //下面是具體內容    for (int i = 0; i < len; i++) {     row = sheet.createRow(i + 1);     cell = row.createCell(0, Cell.CELL_TYPE_STRING);     cell.setCellValue(list.get(i).getUserName());     cell = row.createCell(1, Cell.CELL_TYPE_STRING);     cell.setCellValue(list.get(i).getPassword());    }   }    response.setContentType("application/vnd.ms-excel");   response.setCharacterEncoding("utf-8");   //這里對文件名進行編碼,保證下載時漢字顯示正常   String fileName = URLEncoder.encode("用戶.xls", "utf-8");   //Content-disposition屬性設置成以附件方式進行下載   response.setHeader("Content-disposition", "attachment;filename="     + fileName);   OutputStream os = response.getOutputStream();   workbook.write(os);   os.flush();   os.close();  } } 

(四)主要配置文件

上傳文件時需要在配置文件中配置MultipartResolver類,配置后Spring會自動將文件傳成MultipartFile對象,然后就可以進行相應的處理。示例看Controller類。

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans"  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"  xmlns:context="http://www.springframework.org/schema/context"  xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:util="http://www.springframework.org/schema/util"  xsi:schemaLocation="http://www.springframework.org/schema/beans  http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.0.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd  http://www.springframework.org/schema/util  http://www.springframework.org/schema/util/spring-util-3.0.xsd">   <context:component-scan base-package="com.research" />   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">   <property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />   <property name="prefix" value="/WEB-INF/" />   <property name="suffix" value=".jsp" />  </bean>   <!-- 上傳文件解析器配置 -->  <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">   <property name="defaultEncoding" value="UTF-8"></property>   <!-- 上傳文件的大小限制 ,單位是字節-->   <property name="maxUploadSize" value="5242880000000"></property>   <!-- 上傳文件的臨時路徑,上傳完成后會自動刪除 -->   <property name="uploadTempDir" value="upload/temp"></property>  </bean> </beans> 

(五)測試頁面

<html> <head>   <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> </head> <body> <h3>測試下載Excel功能</h3> <form action="file/download.htm" enctype="multipart/form-data" method="post">  <input type="submit" value="下載Excel"></input>  </form>  <h3>測試上傳Excel功能</h3> <form action="file/upload.htm" enctype="multipart/form-data" method="post">  <input type="file" name="file"></input>  <input type="submit" value="上傳Excel"></input>  </form> </body> </html> 

 如果想看完整源碼,可以到我的Github倉庫查看。 其中,上傳文件只處理符合下載模板的文件。若要處理其它文件需要自實現。代碼測試通過無誤。

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


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人91久久精品| 97不卡在线视频| 欧美午夜精品久久久久久浪潮| 欧美日韩在线免费观看| 日韩中文字幕免费视频| 欧美性猛交xxxx免费看漫画| 久久久久久久999| 日本欧美国产在线| 亚洲成色777777在线观看影院| 日日骚久久av| 亚洲成色777777女色窝| 亚洲曰本av电影| 日韩在线播放视频| 色综合五月天导航| 日韩成人黄色av| 精品福利在线视频| 日韩最新在线视频| 亚洲摸下面视频| 欧美日韩人人澡狠狠躁视频| 亚洲免费电影一区| 国产日韩在线播放| 欧美性在线视频| 国产精品视频26uuu| 美日韩精品免费视频| 在线播放国产精品| 成人日韩av在线| 国产精品成人在线| 国产美女被下药99| 热99精品只有里视频精品| 国产在线拍偷自揄拍精品| 亚洲精品电影网站| 久久久人成影片一区二区三区观看| 日韩中文av在线| 中文字幕亚洲自拍| 中文字幕日韩综合av| 日韩av有码在线| 国产精品美女主播在线观看纯欲| 国产美女主播一区| 91久久久久久久| 成人免费视频97| 亚洲欧美精品一区二区| 国产成+人+综合+亚洲欧洲| 国内精品久久久久久久久| 午夜精品久久久久久久久久久久| 国产精品男女猛烈高潮激情| 这里只有视频精品| 中文字幕国内精品| 久久中文字幕一区| 国产一区二区黑人欧美xxxx| 亚洲精品99久久久久| 久久天天躁狠狠躁夜夜av| 一本久久综合亚洲鲁鲁| 成人激情视频在线播放| 国产精品日韩久久久久| 亚洲香蕉av在线一区二区三区| 97在线观看免费高清| 日韩电视剧在线观看免费网站| 国产99久久精品一区二区永久免费| 亚洲人a成www在线影院| 国产欧美一区二区三区视频| 欧美精品激情blacked18| 97精品视频在线观看| 国内精久久久久久久久久人| 色哟哟亚洲精品一区二区| 91久久精品国产| 国产精品色婷婷视频| 欧美成人激情视频免费观看| 日韩一区二区三区xxxx| 国产精品露脸av在线| 亚洲精品之草原avav久久| 日韩精品有码在线观看| 亚洲美女视频网站| 欧美日韩视频免费播放| 成人网在线视频| 8090成年在线看片午夜| 亚洲嫩模很污视频| 欧美激情综合亚洲一二区| 欧美在线xxx| 岛国精品视频在线播放| 国产精品久久久久久久久久新婚| 日韩精品在线观| 日韩三级成人av网| 成人精品福利视频| 欧美第一黄网免费网站| 国产精品入口夜色视频大尺度| 97超级碰碰碰| 亚洲香蕉av在线一区二区三区| 国产精品视频yy9099| 国产日本欧美视频| 国产一级揄自揄精品视频| 亚洲男女自偷自拍图片另类| 欧美丰满老妇厨房牲生活| 日韩av成人在线观看| 国产精品成人国产乱一区| 欧美一区视频在线| 国产精品久久久久久网站| 国产精品毛片a∨一区二区三区|国| 一区二区三区黄色| 美女精品久久久| 日本欧美在线视频| 国产精品日韩专区| 久久精品视频网站| 久久国产精品影片| 欧美电影在线播放| 91夜夜未满十八勿入爽爽影院| 欧美激情久久久久久| 久久久精品国产亚洲| 国产视频在线一区二区| 久久久91精品国产一区不卡| 中文字幕亚洲情99在线| 91在线观看欧美日韩| 亚洲激情视频在线| 日韩av在线看| 亚洲午夜精品视频| 欧美寡妇偷汉性猛交| 97视频在线播放| 国产精品男女猛烈高潮激情| 久久久国产视频| 日本精品久久中文字幕佐佐木| 亚洲精品第一页| 97久久久久久| 国产成人综合亚洲| 欧美怡红院视频一区二区三区| 久久综合网hezyo| 亚洲欧洲在线视频| 欧美在线性爱视频| 精品国产欧美一区二区三区成人| 精品国偷自产在线视频99| 久久久久亚洲精品国产| 国内精品久久久久久久| 国产丝袜视频一区| 国产午夜精品一区理论片飘花| 少妇高潮久久久久久潘金莲| 国产精品福利无圣光在线一区| 亚洲欧美变态国产另类| 亚洲变态欧美另类捆绑| 在线视频日本亚洲性| 国产成人久久精品| www亚洲欧美| 精品亚洲一区二区三区四区五区| 国产精品91一区| 欧美亚洲国产视频| 一本色道久久88精品综合| 亚洲性日韩精品一区二区| 国产精品精品一区二区三区午夜版| 国产精品成人免费视频| 国产一区二区三区在线观看网站| 亚洲国产精品悠悠久久琪琪| 亚洲欧美日韩区| 97精品伊人久久久大香线蕉| 日本久久久久久久久久久| 一本大道久久加勒比香蕉| 91色琪琪电影亚洲精品久久| 欧美日韩亚洲一区二区三区| 91国偷自产一区二区三区的观看方式| 日韩中文字幕国产| 国产中文字幕91| 欧美性受xxxx白人性爽| 久久久久99精品久久久久| 亲子乱一区二区三区电影| 欧美亚洲一区在线| 精品国模在线视频| 一道本无吗dⅴd在线播放一区| 欧美专区日韩视频|