`
wdmcygah
  • 浏览: 62302 次
社区版块
存档分类
最新评论

SpringMVC下Excel文件的上传下载实现

阅读更多

 在实际应用中,经常会遇到上传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仓库查看:https://github.com/wdmcygah/research-spring。 其中,上传文件只处理符合下载模板的文件。若要处理其它文件需要自实现。代码测试通过无误。

 

 

分享到:
评论

相关推荐

    简单的上传下载excel的springmvc项目源码

    在本项目中,"简单的上传下载excel的springmvc项目源码"是一个面向初学者的教程,旨在帮助学习者掌握如何在Spring MVC框架中处理Excel文件的上传与下载。Spring MVC是Spring框架的一部分,用于构建Web应用程序,而...

    excel的上传下载

    综上所述,"Excel的上传下载"在SSM框架下涉及了前端交互、文件操作、数据库操作、数据转换等多个环节,这些都需要开发者具备扎实的Java基础、Web开发经验以及对数据库和Excel处理的理解。通过熟练运用SSM框架,可以...

    SpringMVC中文件的上传和下载

    以上就是Spring MVC中文件上传和下载的基本实现方法。在实际应用中,你可能还需要处理更复杂的情况,比如多文件上传、文件类型验证、错误处理等。通过理解这些基本概念,你可以根据项目需求进行扩展和优化。

    使用SpringMVC导入导出excel

    用户上传Excel文件时,可以使用`HttpServletRequest`的`getPart`或`getParts`方法获取上传的文件。然后,使用Apache POI库读取并解析Excel内容: ```java @RequestMapping(value = "/import", method = Request...

    SpringMvc+POI 处理Excel的导入操作

    在SpringMVC中,文件上传是通过`MultipartResolver`接口实现的,默认情况下SpringMVC使用的是`CommonsMultipartResolver`。在处理文件上传时,首先需要配置`MultipartResolver`。 #### 六、总结 本文详细介绍了如何...

    非常详细的用 java(springmvc+mybatis)实现excel导入功能并且保存到数据库

    在本实例中,使用了文件上传技术来实现Excel文件上传。在本实例中,使用了文件上传技术来实现批量导入客户的功能,包括文件选择、上传和验证等。 知识点10:错误处理 在本实例中,使用了错误处理技术来处理异常...

    文件上传Excel解析相关的jar

    本资源中提到的"文件上传Excel解析相关的jar"是针对使用Java和SpringMVC进行Excel文件操作时所必需的库文件。 首先,文件上传是Web应用的基本功能之一。在SpringMVC中,我们可以利用`MultipartFile`接口来处理文件...

    SpringMVC下实现Excel文件上传下载

    在上述代码中,我们看到了如何在SpringMVC框架下实现Excel文件的上传和下载功能。首先,我们需要在项目中引入必要的依赖,包括SpringMVC、Apache POI以及文件上传的相关库。 对于文件上传,SpringMVC通过`@...

    poi excel 读写 2007 springmvc

    结合Spring MVC,我们可以创建一个Controller,处理HTTP请求,读取或写入Excel文件。例如,创建一个接收文件上传的接口,然后使用Apache POI处理文件: ```java @PostMapping("/upload") public ResponseEntity&lt;?&gt; ...

    springMVC导入EXCEL

    本文将深入探讨如何使用Spring MVC实现Excel文件的导入功能。 首先,我们需要理解Spring MVC处理文件上传的基本原理。Spring MVC通过`@RequestParam`注解来接收上传的文件,通常与`MultipartFile`接口一起使用。`...

    springMVC测试上传文件并在页面上显示

    总结来说,实现"springMVC测试上传文件并在页面上显示"的功能,需要处理前端的文件选择与提交,后端的文件接收、存储和解析,以及前端的数据展示。涉及的技术包括HTML5表单、Spring MVC的`@RequestParam`、`...

    springmvc+POI的Excel文件导入导出

    总结起来,"SpringMvc+POI的Excel文件导入导出"涉及到的关键技术包括Spring MVC的文件上传处理、Apache POI的Excel读写操作、以及模板填充和导出。通过熟练掌握这些技术,开发者能够高效地处理企业级应用中的Excel...

    springMVC poi解析ajax上传excel文件,返回json对象\list数组

    此项目是基于springMVC实现的,基本流程为从前台jsp页面使用Ajax文件上传导入excel文件(.xls(97-03)/.xlsx(07以后)),传到后台controller调用相应工具类解析后返回指定参数做后续处理. 1. POIUtil.java工具类 解析...

    完美整合框架包(Spring+SpringMVC+mybitas+文件上传下载+邮件+短信支持+生成PDF、Excel)

    标题中的“完美整合框架包”指的是一个集合了多个核心Java技术的综合应用,这些技术包括Spring、SpringMVC、MyBatis以及相关的辅助功能,如文件上传下载、邮件服务、短信支持、PDF和Excel的生成。这个框架整合的目的...

    基于Spring Mvc实现的Excel文件上传下载示例

    在本文中,我们将深入探讨如何使用Spring MVC框架来实现Excel文件的上传与下载功能。Spring MVC是Spring框架的一部分,专门用于构建Web应用程序,提供了一种模型-视图-控制器(MVC)架构模式,简化了处理HTTP请求和...

    SpringMvc+POI 导入Excel文件

    在这个项目中,我们将探讨如何结合SpringMvc和POI来实现Excel文件的导入功能,同时也会涉及Jquery.form.js插件提供的异步表单提交方式。 首先,要实现Excel文件的导入,我们需要理解SpringMvc中的控制器...

    SpringMvc+POI 导入Excel

    本项目是关于如何在SpringMvc中利用POI库来实现Excel文件的导入功能,这在数据录入、批量处理或数据分析场景中非常常见。 首先,我们需要理解SpringMvc中的控制器(Controller)如何接收文件上传请求。在描述中提到...

    SpringMVCAjax_UpDown_Excel

    总结起来,"SpringMVCAjax_UpDown_Excel"项目展示了如何在SpringMVC环境中利用Ajax技术实现Excel文件的无刷新上传和下载。这涉及到SpringMVC的控制器处理、Ajax请求交互以及使用Apache POI处理Excel文件。通过这样的...

    基于SpringMVC的文件上传(兼容IE8)

    SpringMVC同样可以处理Excel文件,可以使用Apache POI库解析Excel内容。 ```java Workbook workbook = WorkbookFactory.create(new FileInputStream(targetFile)); Sheet sheet = workbook.getSheetAt(0); for ...

Global site tag (gtag.js) - Google Analytics