博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
EasyUi通过POI 实现导出xls表格功能
阅读量:5105 次
发布时间:2019-06-13

本文共 2708 字,大约阅读时间需要 9 分钟。

  Spring +EasyUi+Spring Jpa(持久层)

EasyUi通过POI 实现导出xls表格功能

  EasyUi界面:

  

  点击导出按钮实现数据导入到xls表格中

  第一步:修改按钮事件:

@Controller

@ParentPackage("struts-default")
@Namespace("/")
@Scope("prototype")
public class SubAreaAction extends ActionSupport implements ModelDriven<Subarea>

  //注入service层

  @Resource

      private SubAreaservice subareaservice;    

  //导出按钮绑定的事件

            function doExport() {

    //实现访问action的有三种方式:form表单提交、js中调用submit方法、location.href。

                location.href="${pageContext.request.contextPath}/subArea_Export.action"
            }

第二步:在action中提供方法:

    

    @Action(value = "subArea_Export")
    public String subAreaExport() throws IOException {
        // 查询所有的数据
        List<SubArea> list = subareaservice.findSubArea();
        if (list != null && list.size() > 0) {
          //2.创建空的excel文件,在sheet页中设置标题行
          //2.1使用workbook创建空excel
            HSSFWorkbook wb = new HSSFWorkbook();

     //2.2在excel中创建空sheet

            HSSFSheet cs = wb.createSheet();
           //2.3在sheet中创建标题行
            HSSFRow row = cs.createRow(0);

          //2.4在标题行创建单元格,赋值

            row.createCell(0).setCellValue("分区编号");
            row.createCell(1).setCellValue("分区地址");
            row.createCell(2).setCellValue("分区关键字");
            row.createCell(3).setCellValue("分区辅助关键字");
            row.createCell(4).setCellValue("区域编号");
            int index = 1;

  //3.循环分区数据,将数据填充到excel中

            for (SubArea subarea : list) {

      //创建新行

                HSSFRow row1 = cs.createRow(index++);

      //创建新单元格,赋值

                row1.createCell(0).setCellValue(subarea.getId());
                row1.createCell(1).setCellValue(subarea.getAddress());
                row1.createCell(2).setCellValue(subarea.getKeyWords());
                row1.createCell(3).setCellValue(subarea.getAssistKeyWords());

  

                if (subarea.getFixedArea() != null) {
                    row1.createCell(4).setCellValue(subarea.getFixedArea().getId());
                } else {
                    row1.createCell(4).setCellValue("信息未初始化");
                }
            }
           //4.设置文件下载响应参数:文件名、一个流两个头
            String filename = "ceshi.xls";

    //获取浏览器类型

            String header = ServletActionContext.getRequest().getHeader("User-Agent");
            
            String mimeType = ServletActionContext.getServletContext().getMimeType(filename);
            filename = FileUtils.encodeDownloadFilename(filename, header);
           //一个流:response的输出流
            ServletOutputStream os = ServletActionContext.getResponse().getOutputStream();
            //两个头之一:content-type,告诉浏览器返回的数据格式
            ServletActionContext.getResponse().setContentType(mimeType);

    //两个头之二:content-disposition,告诉浏览器打开数据的方式,下载方式打开:attachment;filename=【文件名】

            ServletActionContext.getResponse().setHeader("content-disposition", "attachment;filename=" + filename);

           //5.使用response将文件返回到前台

            wb.write(os);
        }
        return NONE;
    }

第三步:通过controller层调用service层

@Service

@Transactional
public class SubAreaserviceimp implements SubAreaservice {

  @Override

    public List<SubArea> findSubArea() {
        // TODO Auto-generated method stub
        return subareadao.findAll();
    }

}

由于此测试持久层用到JPA所以不能处理持久层的代码了。

直接测试。

测试结果如图:

 

转载于:https://www.cnblogs.com/sjzxs/p/9438292.html

你可能感兴趣的文章
json数据在前端(javascript)和后端(php)转换
查看>>
[Serializable]的应用--注册码的生成,加密和验证
查看>>
Groovy中那些神奇注解之ToString
查看>>
Day19内容回顾
查看>>
第七次作业
查看>>
MySql update inner join!MySql跨表更新 多表update sql语句?如何将select出来的部分数据update到另一个表里面?...
查看>>
我最宏大的个人愿望
查看>>
北漂周记--第5记--拼命编程
查看>>
比赛总结一
查看>>
SpringBoot项目打包
查看>>
JSP的3种方式实现radio ,checkBox,select的默认选择值
查看>>
Linux操作系统 和 Windows操作系统 的区别
查看>>
《QQ欢乐斗地主》山寨版
查看>>
文件流的使用以及序列化和反序列化的方法使用
查看>>
Android-多线程AsyncTask
查看>>
第一个Spring冲刺周期团队进展报告
查看>>
C++函数基础知识
查看>>
红黑树 c++ 实现
查看>>
Android 获取网络链接类型
查看>>
报表服务框架:WEB前端UI
查看>>