页面放置一个button进行点击导出事件

<h:commandLink target="_parent" value="导出"

           action="#{eveluatesubject.doSaveExcel}"

           styleClass="cssButtonBG">

</h:commandLink>

          

后台的导出方法

/**

  * 导出EXCEL

  * 

  * @param request

  * @return

  */

 public String doSaveExcel() {

  HttpServletRequest request = (HttpServletRequest) FacesContext

    .getCurrentInstance().getExternalContext().getRequest();

  dooutof(request);

return null;

 }

public String dooutof(HttpServletRequest request) {

// 文件名与路径

  String realPath = request.getRealPath("");

  String fileName = "导出的文件名称.xls";

  File file = new File(realPath + "//xxfzpj//tempPath//");//导出文件存放的位置

  if (!file.exists()) {

   file.mkdirs();

  }

  realPath = realPath + "//xxfzpj//tempPath//" + fileName;

// 建立工作薄并写表头

  try {

   WritableWorkbook wwb = Workbook.createWorkbook(new File(realPath));

   WritableSheet ws = wwb.createSheet("Sheet1", 0);// 建立工作簿

// 写表头

   jxl.write.Label label1 = new jxl.write.Label(0, 0, "列1");

   jxl.write.Label label2 = new jxl.write.Label(1, 0, "列2");

   jxl.write.Label label3 = new jxl.write.Label(2, 0, "列3");

   jxl.write.Label label4 = new jxl.write.Label(3, 0, "列4");

   jxl.write.Label label5 = new jxl.write.Label(4, 0, "列5");

ws.addCell(label1);// 放入工作簿

   ws.addCell(label2);

   ws.addCell(label3);

   ws.addCell(label4);

   ws.addCell(label5);

// 写入信息

   List<Map> listmsg = 数据库中读出的内容(运行SQL);

for (int i = 0; i < listmsg.size(); i++) {

    label1 = new jxl.write.Label(0, i + 1, listmsg.get(i).get(

      "subject_id").toString().trim());// 建立第一列

    label2 = new jxl.write.Label(1, i + 1, listmsg.get(i).get(

      "subject_name").toString().trim());// 建立第二列

    if (listmsg.get(i).get("object_name") != null

      && "" != listmsg.get(i).get("object_name")) {

     label3 = new jxl.write.Label(2, i + 1, listmsg.get(i).get(

       "object_name").toString().trim());// 建立第三列

    } else {

     label3 = new jxl.write.Label(2, i + 1, "未定义评价对象名称!");

    }

    label4 = new jxl.write.Label(3, i + 1, listmsg.get(i).get(

      "mode_name").toString().trim());// 建立第四列

    label5 = new jxl.write.Label(4, i + 1, listmsg.get(i).get(

      "type_name").toString().trim());// 建立第五列

    ws.addCell(label1);// 放入工作簿

    ws.addCell(label2);

    ws.addCell(label3);

    ws.addCell(label4);

    ws.addCell(label5);

   }

// 写入Exel工作表

   wwb.write();

   // 关闭Excel工作薄对象

   wwb.close();

// 下载

   FacesContext ctx = FacesContext.getCurrentInstance();

String contentType = "application/x-download";

   HttpServletResponse response = (HttpServletResponse) ctx

     .getExternalContext().getResponse();

response.setContentType(contentType);

   response.setHeader("Content-Disposition", "attachment;filename="

     + new String(fileName.getBytes("gb2312"), "ISO8859-1"));

   HttpServletRequest request1 = (HttpServletRequest) FacesContext

     .getCurrentInstance().getExternalContext().getRequest();

ServletOutputStream out = response.getOutputStream();

byte[] bytes = new byte[0xffff];

   InputStream is = new FileInputStream(new File(realPath));

   int b = 0;

   while ((b = is.read(bytes, 0, 0xffff)) > 0) {

    out.write(bytes, 0, b);

   }

   is.close();

   out.flush();

   ctx.responseComplete();

} catch (Exception e) {

   // TODO Auto-generated catch block

   e.printStackTrace();

  }// 此处建立路径

  return null;

 }

Java学习之道:Java操作Excel之导出下载的更多相关文章

  1. Java学习之道:Java 导出EXCEL

    1.Apache POI简单介绍  Apache POI是Apache软件基金会的开放源代码函式库.POI提供API给Java程式对Microsoft Office格式档案读和写的功能. .NET的开 ...

  2. Java学习之道:Java项目打包发布

    Java项目打包发布 如果只想发布为一个可执行的jar包,使用eclipse的Export功能就可以了 使用eclipse的Export功能,将项目中的所有package打包为一个pet.jar文件, ...

  3. java学习笔记07--日期操作类

    java学习笔记07--日期操作类   一.Date类 在java.util包中定义了Date类,Date类本身使用非常简单,直接输出其实例化对象即可. public class T { public ...

  4. 摘自:java夜未眠之java学习之道

    目前Java可以说是产业界和学术界最热门的语言,许多读者都很急切想把Java学好.除非是武侠小说中的运功传送内力的方式,否则花上一段时间苦学是免不了的.花时间,不打紧,就是怕方法错误,事倍功半.我认为 ...

  5. 【JAVA】使用Aphache poi操作EXCEL 笔记

    1 下载poi,地址 http://poi.apache.org/ 选择3.9版本. 2 刚开始尝试 把poi.jar放在D:\Program Files\java\jdk1.6.0_20\lib(不 ...

  6. Java 学习笔记(16)——Java数据库操作

    数据库操作是程序设计中十分重要的一个部分,Java内置JDBC来操作数据库 JDBC使用 JDBC--Java Database connecting Java数据库连接:本质上JDBC定义了操作数据 ...

  7. Java 学习笔记(14)—— 文件操作

    java文件操作主要封装在Java.io.File中,而文件读写一般采用的是流的方式,Java流封装在 java.io 包中.Java中流可以理解为一个有序的字符序列,从一端导向到另一端.建立了一个流 ...

  8. Java学习之道:空指针错误求解救????????????

    运行下面这个主方法红色代码的地方就报如下错: https://api.weibo.com/2/users/show.json?access_token=2.00szM9cCc4R_EC6ebcf150 ...

  9. 【java学习笔记】文件操作

    文件操作 java.io.File ①创建删除文件及目录 ②查看文件及目录属性 ③文件过滤器 (PS:不包括文件读写数据) 1.单个文件 创建单个文件,查看属性,删除单个文件. package tmp ...

随机推荐

  1. 基于HTML5 Canvas的CSG构造实体几何书架

    CSG 构造实体几何这个概念在工业水利水电施工上.游戏上已经有很多人使用了,最简单的实体表示叫作体元,通常是形状简单的物体,如立方体.圆柱体.棱柱.棱锥.球体.圆锥等.根据每个软件包的不同这些体元也有 ...

  2. 使用Identity Server 4建立Authorization Server (5)

    预备知识: http://www.cnblogs.com/cgzl/p/7746496.html 第一部分: http://www.cnblogs.com/cgzl/p/7780559.html 第二 ...

  3. 从成本角度看Java微服务

    近年来,微服务因其良好的灵活性和伸缩性等特点备受追捧,很多公司开始采用微服务架构或将已有的单体系统改造成微服务.IBM也于近日开源了轻量级Java微服务应用服务器 Open Liberty .但是采用 ...

  4. JS 引用类型

    object类型: js中大多数引用类型都是Object类型的实例.创建object实例有两种方法:第一种是使用new操作符后跟Object构造函数. var obj = new Object();o ...

  5. spring boot跨域设置

    定义 跨域是指从一个域名的网页去请求另一个域名的资源 跨域背景 限制原因 如果一个网页可以随意地访问另外一个网站的资源,那么就有可能在客户完全不知情的情况下出现安全问题 为什么要跨域 公司内部有多个不 ...

  6. [转载] PHP工作模型与运行机制

    转载自http://www.nowamagic.net/librarys/veda/detail/350 PHP的工作模型非常特殊.从某种程度上说,PHP和ASP.ASP.NET.JSP/Servle ...

  7. Vue浅谈

    谈Vue 最近在学习Vue相关的知识点并且也做一些练手,就在学习过程中出现的各种坑爹的地方做一个总结!之后再遇到也不会抓瞎. 1.Vue工程的安装 (1)首先先安装node.js这是Vue的运行基础. ...

  8. vim7.3中文乱码问题

    在测试机安装vim7.3之后编辑中文文本出现乱码问题. vim在编译安装的时候: ./configure --enable-gdb --enable-multibyte --enable-cscope ...

  9. mysql主从同步+mycat读写分离+.NET程序连接mycat代理

    背景 最近新项目需要用到mysql数据库,并且由于数据量大的原因,故打算采用1主1从(主数据库负责增.删.改操作:从数据库负责查操作)的数据库架构,在实现主从之后还要实现读写分离的代理,在网上搜寻了很 ...

  10. 在VirtualBox 虚拟机中安装CentOS7 64位实验基础系统

    1.将CentOS-7-x86_64-Minimal ISO加载入虚拟机,选择安装CentOS 7 2.启动欢迎画面,保持默认,选择 继续 3.安装参数设置 3-1.设置时区以便同步时间,将时区更改为 ...