jsp下载excel文件

jsp下载excel文件的的实现方法很多,今天也遇到这个问题,乱敲了一阵,终于搞定了,记下来和朋友们分享吧。

假设需要下载excel文件的jsp页面名为:down.jsp

对应的后台action名为:downExcel.java(用struts实现,其他框架也类似)

在downExcel.java的添加downAction方法,实现下载步骤

public ActionForward downAction(ActionMapping mapping, ActionForm form,
    HttpServletRequest request, HttpServletResponse response) throws IOException {
   java.io.OutputStream o = response.getOutputStream();
   byte b[] = new byte[500];
   java.io.File fileLoad = new java.io.File(request.getRealPath("/WEB-INF/"+"/f.xls"));
   //System.out.println(fileLoad.getPath());
   response.reset();

response.setContentType("application/vnd.ms-excel");

response.setHeader("content-disposition",
     "attachment; filename=text.xls");
   long fileLength = fileLoad.length();
   String length1 = String.valueOf(fileLength);
   response.setHeader("Content_Length", length1);
   java.io.FileInputStream in = new java.io.FileInputStream(fileLoad);
   int n;
   while ((n = in.read(b)) != -1) {
    o.write(b, 0, n);
   }

in.close();
   o.close();
  
   return null;
}

蓝色部分就是要下载的excel文件的路径,注意更改就可以了。

然后就是JSP页面部分了:

在down.jsp中放上一个‘下载’按钮:

<input type="button" value="下载模板" class="bt2" onclick="down();" />

还有一个脚本:

function down(){
var action = "<%=request.getContextPath() %>/downExcel.do?method=downAction";
window.location=action;
}

OK!搞定了 ,为什么要把下载的实现部分放到后台?原本我是将这部分放到另外一个页面(anthor.jsp)的,但是这样下载后anthor.jsp关闭不掉,即使在onload里写上window.close();也是不行的,时间仓促我也没有想其他办法解决,留待有心人来吧,呵呵,莫忘告诉我,O(∩_∩)O~

另外,看到某兄弟的实现是这样的,亮点在最后两句,我觉得有如果在页面实现下载步骤,应不出该兄弟所说,照贴如下:

<%
    java.io.OutputStream o = response.getOutputStream();
    byte b[] = new byte[500];
    java.io.File fileLoad = new java.io.File(request.getRealPath("/WEB-INF/"+"/f.xls"));
    //System.out.println(fileLoad.getPath());
    response.reset();

response.setContentType("application/vnd.ms-excel");

response.setHeader("content-disposition",
      "attachment; filename=text.xls");
    long fileLength = fileLoad.length();
    String length1 = String.valueOf(fileLength);
    response.setHeader("Content_Length", length1);
    java.io.FileInputStream in = new java.io.FileInputStream(fileLoad);
    int n;
    while ((n = in.read(b)) != -1) {
     o.write(b, 0, n);
    }

in.close();
   out.clear();
    out = pageContext.pushBody();

%>

原文地址:https://www.cnblogs.com/tashaxing/p/8806619.html

时间: 2024-10-31 18:41:08

jsp下载excel文件的相关文章

前端下载excel文件功能的三种方法

1 从后端接收json数据,前端处理生成excel下载 JsonExportExcel的github地址:https://github.com/cuikangjie/JsonExportExcel 这种方式比较适用于该数据需要能够导出下载并且同时要展现在页面的场景 2 通过form表单接收文件 如果后端已经处理成了excel,就不需要前端在处理生成,但是Ajax能够返回的数据格式只能为html,script,json,xml,不能直接接受excel文件,如果你直接通过ajax去获取文件就会报错.

JSP导出Excel文件

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%> <%@ taglib uri="http://java.sun.c

解决:下载EXCEL文件,自动用迅雷下载aspx

解决:下载EXCEL文件,自动用迅雷下载aspx if (Request.QueryString["id"] != null && !string.IsNullOrEmpty(Request.QueryString["id"].ToString())) { if (Request.QueryString["oid"] != null && !string.IsNullOrEmpty(Request.QueryStr

C# 之 下载EXCEL文件,自动用迅雷下载aspx

在浏览器中导出 Excel 得时候,如果浏览器绑定了迅雷,则会下载aspx文件. 解决:下载EXCEL文件,自动用迅雷下载aspx if (Request.QueryString["id"] != null && !string.IsNullOrEmpty(Request.QueryString["id"].ToString())) { if (Request.QueryString["oid"] != null &&am

下载EXCEL文件Utils

import jxl.*; import jxl.biff.DisplayFormat; import jxl.format.Alignment; import jxl.format.BoldStyle; import jxl.format.Border; import jxl.format.BorderLineStyle; import jxl.format.*; import jxl.format.VerticalAlignment; import jxl.write.*; import j

angularJS通过post方法下载excel文件

最近工作中遇到,要使用angularJS的post方法来下载excel的情况.网上找到一个帖子:http://stackoverflow.com/questions/22447952/angularjs-http-post-convert-binary-to-excel-file-and-download ,改动了里面部分代码搞定. 详细代码: $http.post($rootScope.restful_api.last_output_excel,body_data,{responseType:

NodeJs实现下载Excel文件

nodejs作为一门新的语言,报表功能也不是十分完善. (1).js-xlsx : 目前 Github 上 star 数量最多的处理 Excel 的库,支持解析多种格式表格XLSX / XLSM / XLSB / XLS / CSV,解析采用纯js实现,写入需要依赖nodejs或者FileSaver .js实现生成写入Excel,可以生成子表Excel,功能强大,但上手难度稍大.不提供基础设置Excel表格api例单元格宽度,文档有些乱,不适合快速上手: https://github.com/S

【小坑】java下载excel文件

excel文件的导入导出是很常见的功能,这次做了个下载的功能,踩了一些坑,记下来避免以后重复踩…… 1.inputstream序列化问题 Could not write JSON document: No serializer found for class java.io.FileDescriptor and no properties discovered to create BeanSerializer 客户端调取服务端上传,从前台获取的file文件中拿到inputstream,做一些判断

下载Excel文件功能通过火狐浏览器下载没有后缀名

最近遇到一个问题,用导出Excelwe文件使用Chrome浏览器是没有问题的,但是用火狐浏览器会出现下载的Excel文件没有后缀名.检查了很多东西都没找到原因.最后和之前的下载功能做对比发现,Excel的文件名不一样,之前的Excel文件名没有时间戳 ,文件名是:xxx2019-08-12 12_23_23.xls,通过Chrome和火狐对比发现,火狐会把空格之后的部分截取掉,导致文件后缀名也被截取掉了.解决办法是文件改为xxx2019-08-12_12_23_23.xls,这样问题就解决了.