web中输出Excel文件

原创 2016年11月22日 15:15:20

示例:

先来一段代码MyServlet.java

 OutputStream os = response.getOutputStream();
 response.reset();
 // response.addHeader("Cache-Control", "no-transform, max-age=0");
 response.setCharacterEncoding("UTF-8");
 response.setContentType("application/vnd.ms-excel");
 String filename = java.net.URLEncoder.encode("电子订单", "UTF-8");
 response.setHeader("content-disposition", "attachment;filename=" + filename + ".xls");
 os.write(exportExcel.exportExcelWithMultiSheets("电子订单", headers, keys, lists, "yyyy-mm-dd",sheetNames));
 os.flush();
 os.close();

示例care1:

response.setContentType(“application/vnd.ms-excel”);
response.setCharacterEncoding(“UTF-8”);


API - javax.servlet.ServletResponse.setContentType(String type)

Sets the content type of the response being sent to the client, if the response has not been committed yet. The given content type may include a character encoding specification, for example, text/html;charset=UTF-8. The response’s character encoding is only set from the given content type if this method is called before getWriter is called.

给定的type里面可以包含编码描述,比如说text/html;charset-UTF-8

API - javax.servlet.ServletResponse.setCharacterEncoding(String charset)

Sets the character encoding (MIME charset) of the response being sent to the client, for example, to UTF-8. If the character encoding has already been set by setContentType or setLocale, this method overrides it. Calling setContentType with the String of text/html and calling this method with the String of UTF-8 is equivalent with calling setContentType with the String of text/html; charset=UTF-8.

如果编码已经通过setContentType指定,这个方法会重新设置编码。调用
setContentType(“text/html”);
setCharacterEncoding(“UTF-8”);等同于
setContentType(“text/html;charset=UTF-8”);

HTTP content-type 对照表
MIME TYPE:也就是资源的媒体类型

示例care2:

response.setHeader(“content-disposition”, “attachment;filename=” + filename + “.xls”);


Content-disposition (C++版介绍)
Content-disposition 是 MIME 协议的扩展,MIME 协议指示 MIME 用户代理如何显示附加的文件。当 Internet Explorer 接收到头时,它会激活文件下载对话框,它的文件名框自动填充了头中指定的文件名。(请注意,这是设计导致的;无法使用此功能将文档保存到用户的计算机上,而不向用户询问保存位置。)

服务端向客户端游览器发送文件时,如果是浏览器支持的文件类型,一般会默认使用浏览器打开,比如txt、jpg等,会直接在浏览器中显示,如果需要提示用户保存,就要利用Content-Disposition进行一下处理,关键在于一定要加上attachment:

response.setHeader(“Content-Disposition”,”attachment;filename=FileName.txt”);

备注:这样浏览器会提示保存还是打开,即使选择打开,也会使用相关联的程序比如记事本打开,而不是IE直接打开了。

Content-Disposition就是当用户想把请求所得的内容存为一个文件的时候提供一个默认的文件名。具体的定义如下:

content-disposition = “Content-Disposition” “:”

disposition-type *( “;” disposition-parm )

disposition-type = “attachment” | disp-extension-token

disposition-parm = filename-parm | disp-extension-parm

filename-parm = “filename” “=” quoted-string

disp-extension-token = token

disp-extension-parm = token “=” ( token | quoted-string )

那么由上可知具体的例子:

Content-Disposition: attachment; filename=“filename.xls”

当然filename参数可以包含路径信息,但User-Agnet会忽略掉这些信息,只会把路径信息的最后一部分做为文件名。当你在响应类型为application/octet- stream情况下使用了这个头信息的话,那就意味着你不想直接显示内容,而是弹出一个”文件下载”的对话框,接下来就是由你来决定“打开”还是“保存” 了。

注意事项:

1.当代码里面使用Content-Disposition来确保浏览器弹出下载对话框的时候。 response.addHeader(“Content-Disposition”,”attachment”);一定要确保没有做过关于禁止浏览器缓存的操作。如下:

response.setHeader(“Pragma”, “No-cache”);
response.setHeader(“Cache-Control”, “No-cache”);
response.setDateHeader(“Expires”, 0);

不然会发现下载功能在opera和firefox里面好好的没问题,在IE下面就是不行,就是找不到文件。

使用web程序导出Excel,PDF和CSV三种文件

写在前面最近参与了一个后台的项目,时间一直比较忙,也连续有段时间没有记东西了。这两天做了个节目广告排期的导出功能,里面有用到三种文件的导出,分别是Excel,PDF和CSV文件。网上有很多文章讲解的比...
  • ForeverSunshine
  • ForeverSunshine
  • 2017年01月11日 19:52
  • 2022

javaweb项目-将数据导出为excel文件思路总结

在生成报表时需要将数据转成excel的文件形式进行下载用,这类方法网上有很多,自己总结一下,方便后期自己查看。 Jsp: 导出全部 Action /** * 导出所有用户信息到...
  • q12345qazxc
  • q12345qazxc
  • 2016年06月06日 14:16
  • 2886

jxl在web项目中以IO流的形式写入excel文件

package cn.itcast.poi; import java.io.IOException; import java.io.OutputStream; import java.io.Prin...
  • u010963948
  • u010963948
  • 2013年08月26日 10:21
  • 1227

Web导出excel的几种方法

在项目中我们经常遇到需要将报表导出成excel下载保存下来,在不同的要求和不同的资源情况下我们有不同的处理方式。在这里我将谈谈我所遇到的几种情况和遇到的一些问题。  总的来说可以分为:服务器端生成和...
  • lxk2013
  • lxk2013
  • 2016年04月28日 10:14
  • 1413

通过web端转换excel为xml文件,可一次性转换多个xml

  • 2017年07月26日 15:16
  • 13.01MB
  • 下载

java 导出Excel文件 网页方式打开 web.xml配置

  • 2010年11月17日 15:47
  • 2KB
  • 下载

Java web中不同浏览器间导出Excel文件名称乱码问题解决方案

问题描述:         对于不同浏览器存在对中文编码格式问题,从而在导出Excel文件时,中文文件名出现乱码的情况,即在程序中给要导出的文件指定一个中文名字时,在浏览器上出现的下载框中的文件名出...
  • tongxinxiao
  • tongxinxiao
  • 2015年02月11日 14:49
  • 5976

Java Web获取数据库数据,利用jxl实现数据导出成Excel文件

一、效果图 二、代码 数据库操作类MysqlUtil.java package com.jekin.utils; import java.sql.Connection; import java....
  • FJeKin
  • FJeKin
  • 2016年12月13日 18:14
  • 1701

java web:excel文件上传与解析

0.前言项目中需要解析用户上传的excel文件,校验单元格格式,并数据入库。在实现的过程中遇到了不少问题,并一一解决了,所以总结一下,希望对大家有所帮助。1.页面传递文件这里实现了最简单的形式,注意将...
  • zhangguixian5
  • zhangguixian5
  • 2015年08月23日 15:17
  • 9634

web项目-Excel文件导出

跳坑留下的伤疤都是我们程序员最好的勋章。 文件导出是在web项目中常用的功能之一。在这里我也谈一下本人的拙见。 此次我遇到的是从easyUI框架中查询数据的导出,当然,不管框架怎么变,万变不离其宗,导...
  • qq_34129814
  • qq_34129814
  • 2017年11月24日 17:29
  • 78
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:web中输出Excel文件
举报原因:
原因补充:

(最多只允许输入30个字)