`
zzc1684
  • 浏览: 1223198 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

Spring mvc 下导出Excel文件

阅读更多

1.新建类继承AbstractExcelView

Java代码

    import java.io.OutputStream;  
    import java.util.Map;  
    import javacommon.util.MyUtils;  
    import javax.servlet.http.HttpServletRequest;  
    import javax.servlet.http.HttpServletResponse;  
    import org.apache.poi.hssf.usermodel.HSSFCell;  
    import org.apache.poi.hssf.usermodel.HSSFCellStyle;  
    import org.apache.poi.hssf.usermodel.HSSFRow;  
    import org.apache.poi.hssf.usermodel.HSSFSheet;  
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
    import org.springframework.web.servlet.view.document.AbstractExcelView;  
    public class ViewExcel extends AbstractExcelView {  
        @Override  
        protected void buildExcelDocument(Map<String, Object> obj,  
                HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response)  
                throws Exception {  
            HSSFSheet sheet = workbook.createSheet("list");    
            sheet.setDefaultColumnWidth((short) 12);    
            HSSFCell cell = getCell(sheet, 0, 0);    
            setText(cell, "Spring Excel test");    
            HSSFCellStyle dateStyle = workbook.createCellStyle();    
            //dateStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat("mm/dd/yyyy"));    
            cell = getCell(sheet, 1, 0);    
            cell.setCellValue("日期:2008-10-23");    
            //cell.setCellStyle(dateStyle);    
            getCell(sheet, 2, 0).setCellValue("测试1");    
            getCell(sheet, 2, 1).setCellValue("测试2");  
            HSSFRow sheetRow = sheet.createRow(3);    
            for (short i = 0; i < 10; i++) {    
                sheetRow.createCell(i).setCellValue(i * 10);    
            }    
            String filename = "测试.xls";//设置下载时客户端Excel的名称     
            filename = MyUtils.encodeFilename(filename, request);//处理中文文件名  
            response.setContentType("application/vnd.ms-excel");     
            response.setHeader("Content-disposition", "attachment;filename=" + filename);     
            OutputStream ouputStream = response.getOutputStream();     
            workbook.write(ouputStream);     
            ouputStream.flush();     
            ouputStream.close();     
        }  
    }  

 

处理中文文件名的方法:

Java代码

    /**  
         * 设置下载文件中文件的名称  
         *   
         * @param filename  
         * @param request  
         * @return  
         */    
        public static String encodeFilename(String filename, HttpServletRequest request) {    
          /**  
           * 获取客户端浏览器和操作系统信息  
           * 在IE浏览器中得到的是:User-Agent=Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; Maxthon; Alexa Toolbar)  
           * 在Firefox中得到的是:User-Agent=Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.7.10) Gecko/20050717 Firefox/1.0.6  
           */    
          String agent = request.getHeader("USER-AGENT");    
          try {    
            if ((agent != null) && (-1 != agent.indexOf("MSIE"))) {    
              String newFileName = URLEncoder.encode(filename, "UTF-8");    
              newFileName = StringUtils.replace(newFileName, "+", "%20");    
              if (newFileName.length() > 150) {    
                newFileName = new String(filename.getBytes("GB2312"), "ISO8859-1");    
                newFileName = StringUtils.replace(newFileName, " ", "%20");    
              }    
              return newFileName;    
            }    
            if ((agent != null) && (-1 != agent.indexOf("Mozilla")))    
              return MimeUtility.encodeText(filename, "UTF-8", "B");    
          
            return filename;    
          } catch (Exception ex) {    
            return filename;    
          }    
        }   

 

2接下来在你的下载 Controller里面返回ModelAndView 即可

Java代码

  1. /** 
  2.     * 导出Excel 
  3.     * @param model 
  4.     * @param projectId 
  5.     * @param request 
  6.     * @return 
  7.     */  
  8.    @RequestMapping(value="/dcExcel",method=RequestMethod.GET)  
  9.     public ModelAndView toDcExcel(ModelMap model, HttpServletRequest request){  
  10.        List list = new ArrayList();  //测试数据没有用到  
  11.        Map map = new HashMap();    
  12.        list.add("test1");    
  13.        list.add("test2");    
  14.        map.put("list", list);    
  15.        ViewExcel viewExcel = new ViewExcel();    
  16.        return new ModelAndView(viewExcel, model);   
  17.    } 
分享到:
评论

相关推荐

    spring MVC 导出excel

    在实际应用中,我们可能需要将数据库中的大量数据导出到Excel文件,以便用户可以离线查看或进一步处理。Spring MVC 提供了丰富的工具和库,如Apache POI,来支持这样的需求。 Apache POI 是一个开源项目,它允许...

    spring mvc excel common view

    标题“spring mvc excel common view”涉及的是Spring MVC框架中处理Excel导出的常见视图技术。在Web应用中,经常需要将数据导出为Excel格式供用户下载,Spring MVC提供了一种优雅的方式实现这一功能。 Spring MVC...

    Easyui.+.Spring.Mvc导出Excel

    "Easyui Spring Mvc导出Excel"是一个常见的话题,它涉及了三个关键技术:Easyui、Spring MVC以及Excel导出。 Easyui是一个基于jQuery的UI框架,提供了一系列美观且易于使用的组件,如表格、下拉框、对话框等。在Web...

    Jett+Spring MVC实现Excel导出

    在本文中,我们将深入探讨如何使用Jett和Spring MVC框架来实现Excel文件的导出功能。Jett是一个轻量级的Java库,专门用于处理Excel数据的读取和写入,而Spring MVC则是广泛应用于构建Web应用的MVC(Model-View-...

    Jxls+Spring MVC实现Excel导出

    "Jxls+Spring MVC实现Excel导出"的主题聚焦于如何利用Jxls库和Spring MVC框架来实现这一功能。Jxls是一个强大的Java库,它扩展了Apache POI,使得在Excel模板上进行编程变得简单,而Spring MVC是Spring框架的一部分...

    Spring MVC 学习笔记 十二 PDF/Excel格式输出

    对于PDF和Excel格式的输出,Spring MVC可以通过Apache POI库来处理Excel,使用Flying Saucer或iText库来生成PDF。这些库能够将HTML内容转换为所需的格式,方便导出和下载。 总的来说,Spring MVC是Spring框架的重要...

    spring mvc框架依赖全面jar

    在本压缩包中包含了一系列与Spring MVC相关的jar文件,这些文件是构建和运行Spring MVC项目所必需的依赖。 首先,`hibernate3.jar` 是Hibernate ORM框架的库,它允许开发者将Java对象映射到关系数据库,提供了数据...

    spring mvc easyui-POI导出excel封装源码

    总结来说,"spring mvc easyui-POI导出excel封装源码"项目是将Spring MVC的后端处理能力与EasyUI的前端展示效果以及POI的Excel处理功能相结合,实现了一个功能强大且界面美观的Excel数据导出功能。这个项目对于需要...

    Spring3 MVC + POI 实现 Excel与MySQL 的导入导出

    本主题聚焦于如何利用Spring3 MVC框架结合Apache POI库来实现在Java环境中Excel与MySQL数据库之间的数据导入与导出。 Spring3 MVC是Spring框架的一个组件,专门用于构建Web应用程序,它提供了模型-视图-控制器(MVC...

    用spring MVC 生成Excel和PDF.docx

    这个例子展示了如何使用 Spring MVC 和相关的库(Apache POI 和 iText)来动态生成 Excel 和 PDF 文件,提供给用户下载。整个流程涉及到 Spring MVC 的配置、控制器的编写以及与第三方库的集成,实现了从数据到视图...

    spring3.2.5 MVC Poi3.9操作excel批量导入

    使用Spring MVC和Apache POI,我们可以构建一个高效、可扩展的系统,实现从Excel文件批量导入数据到数据库,并能将数据库中的数据导出为Excel文件。这样,数据分析师可以轻松地进行数据预处理和分析。 在Maven2的...

    spring3.0 MVC Poi操作excel批量导入数据库和导出数据

    在本主题中,我们将讨论如何利用Spring 3.0 MVC和Apache POI库来处理Excel文件,实现批量导入数据库和导出数据的功能。 Apache POI是一个强大的开源库,专门用于读写Microsoft Office格式的文件,特别是Excel(....

    Spring MVC 分页组件和JqGrid导出

    JqGrid支持导出表格数据到Excel、CSV、PDF等多种格式,这对于数据分析和共享非常方便。要实现导出,我们需要在后端创建一个处理导出请求的控制器方法,将数据转换为指定格式,然后以文件流的形式返回给前端。在...

    Spring3MVC and POI

    在实际开发中,Spring 3 MVC与Apache POI的结合非常常见,特别是在需要处理大量数据并导出为Excel报表的场景下。例如,你可以创建一个Controller,通过注解路由处理请求,查询数据库获取数据,然后使用POI将数据写入...

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

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

    spring mvc学习+数据分页+数据导入导出

    总的来说,本学习资源涵盖了Spring MVC 3的基础知识,包括注解驱动的控制器、数据库操作、数据分页、数据导入导出以及异常处理等重要概念。通过实践这些内容,你将能够构建出功能完备且健壮的Web应用程序。

    spring3.0 MVC中文教程

    5. **松散耦合**:Spring MVC并不紧密地耦合到servlet或JSP,这意味着可以在不改变框架的情况下更改视图技术。 #### 二、Spring 3.0 MVC系列教程内容概览 1. **第1部分:Spring 3.0 MVC框架简介** - 介绍Spring ...

    springmvc4利用AbstractXlsxStreamingView,根据模板导出excel

    通过以上步骤,你就可以在Spring MVC 4项目中利用`AbstractXlsxStreamingView`根据模板高效地导出Excel文件了。这不仅提高了用户体验,还有效地避免了因内存消耗过大导致的系统性能问题。在实际开发过程中,可以根据...

    19 Spring MVC应用拓展Resource应用于文件下载慕课专栏1

    本节主要探讨如何使用Spring MVC的Resource接口来实现文件下载功能,特别是针对Word、Excel和PDF这三种常用文件格式。 首先,我们需要创建一个Maven Web项目,并添加必要的依赖,包括Spring MVC相关的库,确保项目...

    Spring MVC A Tutorial Second Edition

    Spring MVC内置了多种视图技术的支持,包括JSP、Velocity、FreeMarker、Excel、PDF等。 注解型控制器(Annotation-Based Controllers)是Spring MVC 3.0之后引入的特性,它简化了控制器的配置,允许使用注解来定义...

Global site tag (gtag.js) - Google Analytics