@RequestMapping(value = "downloadExcel", method = RequestMethod.GET)
 public String download(HttpServletRequest request,HttpServletResponse response) throws IOException{
        String fileName="excel文件";
        //填充projects数据
        ExcelUtil excelUtil = new ExcelUtil();
        List<Project> projects = excelUtil.createData();
        List<Map<String,Object>> list = excelUtil.createExcelRecord(projects);
        String columnNames[]={"ID","项目名","销售人","负责人","所用技术","备注"};//列名
        String keys[]   =    {"id","name","saler","principal","technology","remarks"};//map中的key
        ByteArrayOutputStream os = new ByteArrayOutputStream();
        try {
            ExcelUtil.createWorkBook(list,keys,columnNames).write(os);
        } catch (IOException e) {
            e.printStackTrace();
        }
        byte[] content = os.toByteArray();
        InputStream is = new ByteArrayInputStream(content);
        // 设置response参数,可以打开下载页面
        response.reset();
        response.setContentType("application/vnd.ms-excel;charset=utf-8");
        response.setHeader("Content-Disposition", "attachment;filename="+ new String((fileName + ".xls").getBytes(), "utf-8"));
        ServletOutputStream out = response.getOutputStream();
        BufferedInputStream bis = null;
        BufferedOutputStream bos = null;
        try {
            bis = new BufferedInputStream(is);
            bos = new BufferedOutputStream(out);
            byte[] buff = new byte[2048];
            int bytesRead;
            while (-1 != (bytesRead = bis.read(buff, 0, buff.length))) {
                bos.write(buff, 0, bytesRead);
            }
            bos.flush();
        } catch (final IOException e) {
         
         logger.error("导出Excel异常:",e);
            throw e;
        } finally {
            if (bis != null)
                bis.close();
            if (bos != null)
                bos.close();
        }
        return null;
    }
 
 /**
     * 导出Excel
     * @param request
     * @param response
     */
 @RequestMapping(value = "ProcessRequestExcel", method = RequestMethod.GET)
    public void ProcessRequest(HttpServletRequest request,HttpServletResponse response){
        java.text.SimpleDateFormat format = new java.text.SimpleDateFormat("yyyyMMddhhmmss");
        String now = format.format(new Date());
        String exportFileName = "信息导出_"+now+".xls";//导出文件名
        List<Basicinfo> list = getInfoList();
        HSSFWorkbook workBook = null;
        String[] cellTitle = {"序号", "姓名", "性别", "部门"};
        try {
            workBook = new HSSFWorkbook();//创建工作薄
            HSSFSheet sheet = workBook.createSheet();
            workBook.setSheetName(0, "订单信息");//工作簿名称
            HSSFFont font = workBook.createFont();  
            font.setColor(HSSFFont.COLOR_NORMAL);
            font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
            HSSFCellStyle cellStyle = workBook.createCellStyle();//创建格式
            cellStyle.setFont(font);
            cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
            cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
            //创建第一行标题
            HSSFRow titleRow = sheet.createRow((short) 0);//第一行标题
            for(int i = 0,size = cellTitle.length; i < size; i++){//创建第1行标题单元格    
                sheet.setColumnWidth(i,4000);
                HSSFCell cell = titleRow.createCell(i,0);        
                cell.setCellStyle(cellStyle);
                cell.setCellValue(cellTitle[i]);
            }
            //从第二行开始写入数据
            for(int i=1,size = list.size();i<size;i++){
                HSSFRow row = sheet.createRow((short) i);
                Basicinfo entity = list.get(i);
                for (int j = 0,length=cellTitle.length; j < length; j++) {
                    HSSFCell cell = row.createCell(j, 0);// 在上面行索引0的位置创建单元格
                    cell.setCellType(HSSFCell.CELL_TYPE_STRING);// 定义单元格为字符串类型
                    switch(j){// 在单元格中输入一些内容
                    case 0:
                        cell.setCellValue(String.valueOf(i));
                        break;
                    case 1:
                        cell.setCellValue(entity.getName());
                        break;
                    case 2:
                        cell.setCellValue(entity.getSex());
                        break;
                    case 3:
                        cell.setCellValue(entity.getDepart());
                        break;
                    }
                }
            }
             
            // 表示以附件的形式把文件发送到客户端
            response.setHeader("Content-Disposition", "attachment;filename=" + new String((exportFileName).getBytes(), "ISO8859-1"));//设定输出文件头
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");// 定义输出类型
             
            // 通过response的输出流把工作薄的流发送浏览器形成文件
            OutputStream outStream = response.getOutputStream();
            workBook.write(outStream);
            outStream.flush();
            outStream.close();
        }catch(IOException e){
            System.out.println("IO 异常!"+e.getMessage());
            e.printStackTrace();
        }finally{
         
        }
    }
     
    /**
     * 模拟数据库获取信息
     * @return
     */
    @SuppressWarnings("unchecked")
 public List<Basicinfo> getInfoList(){
        List<Basicinfo> list = new ArrayList();
        for(int i=1;i<101;i++){
            Basicinfo entity = new Basicinfo();
            entity.setName("员工"+i);
            entity.setSex(i%2==1?"男":"女");
            entity.setDepart(i>80?"销售部":"财务部");
            list.add(entity);
        }
        return list;
    }
 

Java导出Excel的Springmvc实例的更多相关文章

  1. java导出excel报错:getOutputStream() has already been called for this response

    对于java导出excel报错的问题,查了很多都说是在使用完输出流以后调用以下两行代码即可 out.clear(); out = pageContext.pushBody(); 但这也许是页面上输出时 ...

  2. java导出excel表格

    java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...

  3. java导出excel报表

    1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;impo ...

  4. Java导出Excel和CSV(简单Demo)

    Java导出Excel和CSV的简单实现,分别使用POI和JavaCSV. JavaBean public class ReportInfo { int id; String date; int nu ...

  5. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

  6. java导出excel模板数据

    Java导出excel数据模板,这里直接贴代码开发,流程性的走下去就是步骤: String[] colName=new String[]{"期间","科目代码" ...

  7. java导出excel工具类

    java导出excel须要使用HSSFWorkbook这个类,须要导入poi-3.6-20091214.jar 工具类调用例如以下: package com.qlwb.business.util; i ...

  8. [转载]Java导出Excel

    一.需求介绍 当前B/S模式已成为应用开发的主流,而在开发企业办公系统的过程中,常常有客户这样子要求:把系统数据库中的数据导出到Excel,用户查看报表时直接用Excel打开.或者是:用户已经习惯用E ...

  9. java 通过Apache poi导出excel代码demo实例

    package com.zuidaima.excel.util; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutput ...

随机推荐

  1. 开始在web中使用JS Modules

    本文由云+社区发表 作者: 原文:<Using JavaScript modules on the web> https://developers.google.com/web/funda ...

  2. 使用myeclipse修改项目映射路径

    这里主要做下记录,找到myeclipse中对项目路径进行查看以及修改的地址 如图 点击项目右键 实例url:http://localhost:8080/myFirstServlet/one 对应路径中 ...

  3. HTML 练习js代码位置在head标签

    方式一: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF- ...

  4. XSS Challenges xss-quiz.int21h.jp

    概述: https://xss-quiz.int21h.jp/ Stage #1 payload: <script>alert(document.domain);</script&g ...

  5. 当心Azure跨区域数据传输产生额外费用

    最近同事发现Azure上一台虚拟机的费用环比增加了一部分.后面仔细检查发现费用来自数据传输, 因为这是早期部署的一台Azure虚拟机(Iaas),我们在本地生成备份,然后通过AzCopy到存储账号的B ...

  6. Win7系统修改hosts无法保存怎么办?

    背景 有的时候我们需要修改hosts文件,但是在某些情况下竟提示保存不了.之前有一次IntelliJ IDEA提示我快到期了,于是我到网上找到了一个激活方法,但需要将一个地址放到hosts文件中去,此 ...

  7. Ginger的第一篇博客

    怀着无感的心情,没有技术的身体,写下第一篇博客作为标记. 目前应该会搞清楚数据结构上相关的操作.算法,然后用c语言实现后记录在博客. 我是有目标的咸鱼! 2019/4/19

  8. 4.29 初始mysql

  9. 分布式之 BASE理论

    ------------------------------珍惜眼前的学习机会,当你现在有机会学习各种经验时,一定要倍加珍惜.靠混日子是混不了一辈子的,许多过程都是不能省略的,至少学会这些经验可以让你 ...

  10. BASE64编码原理分析脚本实现及逆向案例

    在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理你又了解多少?今天小编带大家了解一下Base64编码原理分析脚本实现及逆向案例的相关内容.   01编码由来 数 ...