在此,强调一下搜索时关键词的重要性,这样一下子可以定位到文章,否则处于盲人摸象,毫无目的尴尬境地。本篇就是通过export jsp to excel找到的。

原文地址:How to Export Web Page to Excel (in JSP)?

本篇教程我们会看到如何把JSP页面导出到Excel中,会在已有的JSP页面中增加导出excel的功能。

许多时候对于用户来说,可以在excel中看到页面内容是很方便的。公共的方案会被导出成包含一些报告、数字等信息的表格。通过导出数据导出到excel中,最终用户也可以使用excel来做各种的分析,这一点对于你的java基本程序来实现,是有困难的。

假设这就是你的jsp页面:

这是对应的jsp源码(导出excel功能还没有加)。一个包含简单数据表格的jsp页面。

  1. <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
  2. pageEncoding="ISO-8859-1"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  7. <title>Export to Excel - Demo</title>
  8. </head>
  9. <body>
  10. <table align="center" border="2">
  11. <thead>
  12. <tr bgcolor="lightgreen">
  13. <th>Sr. No.</th>
  14. <th>Text Data</th>
  15. <th>Number Data</th>
  16. </tr>
  17. </thead>
  18. <tbody>
  19. <%
  20. for (int i = 0; i < 10; i++) {
  21. %>
  22. <tr bgcolor="lightblue">
  23. <td align="center"><%=i%></td>
  24. <td align="center">This is text data <%=i%></td>
  25. <td align="center"><%=i * i%></td>
  26. </tr>
  27. <%
  28. }
  29. %>
  30. </tbody>
  31. </table>
  32. </body>
  33. </html>

我们会添加一个“导出到excel”的超链接,它会把页面内容导出到excel文件中。那么这个页面会变成这个样子:

下面是新版本的jsp源码。这个版本增加了“导出到excel”超链接,而且增加了相应的功能:

  1. <%@ page language="java" contentType="text/html; charset=ISO-8859-1"
  2. pageEncoding="ISO-8859-1"%>
  3. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
  4. <html>
  5. <head>
  6. <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
  7. <title>Export to Excel - Demo</title>
  8. </head>
  9. <body>
  10. <%
  11. String exportToExcel = request.getParameter("exportToExcel");
  12. if (exportToExcel != null
  13. && exportToExcel.toString().equalsIgnoreCase("YES")) {
  14. response.setContentType("application/vnd.ms-excel");
  15. response.setHeader("Content-Disposition", "inline; filename="
  16. + "excel.xls");
  17. }
  18. %>
  19. <table align="left" border="2">
  20. <thead>
  21. <tr bgcolor="lightgreen">
  22. <th>Sr. No.</th>
  23. <th>Text Data</th>
  24. <th>Number Data</th>
  25. </tr>
  26. </thead>
  27. <tbody>
  28. <%
  29. for (int i = 0; i < 10; i++) {
  30. %>
  31. <tr bgcolor="lightblue">
  32. <td align="center"><%=i + 1%></td>
  33. <td align="center">This is text data <%=i%></td>
  34. <td align="center"><%=i * i%></td>
  35. </tr>
  36. <%
  37. }
  38. %>
  39. </tbody>
  40. </table>
  41. <br><br><br><br><br><br><br><br><br><br><br><br><br><br><br>
  42. <%
  43. if (exportToExcel == null) {
  44. %>
  45. <a href="excel.jsp?exportToExcel=YES">Export to Excel</a>
  46. <%
  47. }
  48. %>
  49. </body>
  50. </html>

导出网页到excel代码解释:

1) 在这个版本的jsp页面中,当你点击“导出到excel”超链接的时候,请求会发送到相同的页面(excel.jsp),但是伴随url参数是 exportToExcel=YES.
 
  1. <a href="excel.jsp?exportToExcel=YES">Export to Excel</a>
 

2) JSP页面一开始会检查参数的正确性。如果这个参数值是YES的话,我们就会看到响应报文中的内容类型,它标识了excel的文件名,并且会在用户的电脑上打开。

 
  1. String exportToExcel = request.getParameter("exportToExcel");
  2. if (exportToExcel != null
  3. && exportToExcel.toString().equalsIgnoreCase("YES")) {
  4. response.setContentType("application/vnd.ms-excel");
  5. response.setHeader("Content-Disposition", "inline; filename="
  6. + "excel.xls");
  7. }

3) 当你点击“导出到excel”超链接的时候,所有页面的内容会被导出excel中。但是,我们可能不想让“导出到excel”的超链接出现在excel中。为了阻止它的出现,我们增加了一个判断条件,判断exportToExcel参数是否出现。如果出现,就意味着内容会被导出到excel中,而且不包括超链接。反之,就意味着我们只是想浏览器显示网页,那么超链接会出现在页面上。

 
  1. <%
  2. if (exportToExcel == null) {
  3. %>
  4. <a href="excel.jsp?exportToExcel=YES">Export to Excel</a>
  5. <%
  6. }
  7. %>

导出页面到excel的显示

但你点击超链接,会弹出一个对话框,问你是否打开或保存文件。点击打开,你会看到下面的内容:
 
 
正如你所看得,导出的文件也会保存你在页面上的格式设置。
 
在下一篇教程中,我们会看到如何导出页面到word文件中
 
你可以下载本次教程中代码解释部分的eclipse工程文件。
 
 
=============================================

注意:

如果没有设置:response.setHeader("Content-Disposition", "attachment; filename=" + filename+".xls");
则默认为当前页面.xls。
比如testexcel.jsp--->则生成testexcel.xls表格

扩展阅读:

[1]在JSP中通过http协议生成excel和word:作者用过jxl之后,选择了http方式生成excel

[2]JSP-EXCEL save defualt in .xls extension, open excel with in the browser

[3]利用HTTP协议,更改输出文件:引出了HTTP1.1协议的重要性

[4]超文本传输协议-HTTP(修订版):详细解释了HTTP1.1协议

[5]Multiple tables data exported to multiple worksheets of the same excel sheet in java:一个excel中,存储在多个sheet

将jsp页面内容保存到excel(转)的更多相关文章

  1. jsp 页面内容导出到Excel中

    日常使用网络资源时经常需要把网页中的内容下载到本地,并且导出到Excel中,现在介绍一种非常简单的方式实现网络资源的下载.只需要讲jsp的最上面加上一句话 <% response.reset() ...

  2. table内容保存到Excel中

    @{ Layout = null; } <html> <head> <title></title> </head> <body> ...

  3. 将查询列表内容保存到excel表格中,并保存到相应的盘中

    1.先导入相应的jar包 2.一个小的Demo测试[实体类+测试类:保存excel的方法] Student实体类 public class Student{ private int id; priva ...

  4. Sql数据保存到Excel文件中

    public string ExportExcel( DataSet ds,string saveFileName) { try { if (ds == null) return "数据库为 ...

  5. 调用获取学生信息的接口,保存到excel里面

    # 2.http: // doc.nnzhp.cn / index.php?s = / 6 & page_id = 14# 调用获取学生信息的接口,保存到excel里面 import requ ...

  6. 调用获取学生信息的接口,保存到excel里面的小程序

    # 2.http: // doc.nnzhp.cn / index.php?s = / 6 & page_id = 14# 调用获取学生信息的接口,保存到excel里面 import requ ...

  7. 批量生成随机字符串并保存到excel

    需要导入jxl.jar,commons-lang-2.6.jar 链接:https://pan.baidu.com/s/1NPPh24XWxkka68x2JQYlYA 提取码:jvj3 链接:http ...

  8. 用python实现批量获取Linux主机简要信息并保存到Excel中 unstable 1.1

    #!/usr/bin/env python3 # -*- coding: utf-8 -*- #filename get_linux_info.py #获取Linux主机的信息 # titles=[' ...

  9. 用Python提取XML里的内容,存到Excel中

    最近做一个项目是解析XML文件,提取其中的chatid和lt.timestamp等信息,存到excel里. 1.解析xml,提取数据 使用python自带的xml.dom中的minidom(也可以用l ...

随机推荐

  1. android greendao3.0 多表关联关系讲解(转)

    转自:http://www.jianshu.com/p/dbec25bd575f 前言 之前用过数据库框架:realm.kjdb,今天准备实践学习一下greendao 3.0.greendao 3.0 ...

  2. #define的使用方法体会

    #define 创建一个宏,该宏是标识符或參数化标识符与标记字符串的关联. 在定义宏之后.编译器可用标记字符串替换源文件里标识符的每一个匹配项. 双击以所有折叠.">语法 #defin ...

  3. python 上传文件下载图片

    python 2.7 poster-0.8.1 requests-2.7.0 #coding:utf-8import urllibimport urllib2import sysimport time ...

  4. Office 365系列(-)

    昨天参加上海微软TechED技术大会,看见很多传说中的大牛,听了涂曙光老师等人的讲座,激情澎湃啊,看见他们对技术以及程序员社区的投入及激情,十分敬佩.自己搞IT行业也已经10多年了,平常都很少写博客和 ...

  5. Leftmost Digit(hdu1060)(数学题)

    Leftmost Digit Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)To ...

  6. java的小知识点

    1 获取当前路径 System.getProperty("user.dir") System.getProperty()参数大全# java.version            ...

  7. php读写csv、xml文件: SimpleExcel

    实例结构: 1. csv2xml.demo.php <?php use SimpleExcel\SimpleExcel; // 这句不能少! require_once ('../lib/Simp ...

  8. android ui篇 自己写界面

    对于一些较为简单的界面则自己进行写. 在这里就需要了解xml文件中一些基本的属性以及android手机的知识. 一.目前手机屏幕像素密度基本有5种情况.(以下像素密度简称密度) 密度 ldpi mdp ...

  9. proguard 不混淆第三方jar包的问题

    导入lib文件,并且用-dontwarn 和 keep class结合试试,例如: -libraryjars libs/log4j.jar -dontwarn org.apache.log4j.*-k ...

  10. MyBatis:学习笔记(4)——动态SQL

    MyBatis:学习笔记(4)——动态SQL 如果使用JDBC或者其他框架,很多时候需要你根据需求手动拼装SQL语句,这是一件非常麻烦的事情.MyBatis提供了对SQL语句动态的组装能力,而且他只有 ...