博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JSP下载txt 和 Excel两种文件
阅读量:5903 次
发布时间:2019-06-19

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

1 下载txt文件 这个花了我不少时间 原因是用ie下载txt文件时是在页面中直接打开了文件.虽然查了一些资料,也看了别人的解决方案,可还是解决不了问题,最后发现是一个字母惹的祸:少写一个字母 嘿嘿 够马虎!!!代码如下:OutputStream o=response.getOutputStream();    byte b[]=new byte[500];    File fileLoad=new File("e:/test.txt");     response.setContentType("application/octet-stream");   response.setHeader("content-disposition","attachment; filename=text.txt");    long fileLength=fileLoad.length();    String length1=String.valueOf(fileLength);    response.setHeader("Content_Length",length1);    FileInputStream in=new FileInputStream(fileLoad);    int n;    while((n=in.read(b))!=-1){     o.write(b,0,n);    }       in.close();    out.clear();    out = pageContext.pushBody();2 下载excel文件 跟下载txt文件时的唯一区别是ContentType值的设置不同:OutputStream o=response.getOutputStream();    byte b[]=new byte[500];    File fileLoad=new File("e:/text.xls");    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);    FileInputStream in=new FileInputStream(fileLoad);    int n;    while((n=in.read(b))!=-1){     o.write(b,0,n);    }       in.close();    out.clear();    out = pageContext.pushBody();  这两个本来是放在一起的,因为我的页面中需要判断是下载的txt文件还是xls文件  在这里给分开了 需要注意的是,最后两句一定要加上,否则会出现getOutputStream()错误的!!!!        实例:<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %>             My JSP 'index.jsp' starting page       普通测试:Down a.txt   中文文件名测试:Down 中文.txt   普通转向:down.txt      down2.jsp: <%@ page language="java" import="java.util.*,java.io.* " pageEncoding="UTF-8"%> <% request.setCharacterEncoding("utf-8"); String filename = request.getParameter("filename"); filename = new String(filename.getBytes("ISO-8859-1"),"UTF-8");  System.out.println(filename); OutputStream o=response.getOutputStream(); byte b[]=new byte[500]; /** * 得到文件的当前路径 * @param args */  String   serverpath=request.getRealPath("\\");  File fileLoad=new File(serverpath+filename); response.setContentType("application/octet-stream"); response.setHeader("content-disposition","attachment; filename="+filename); long fileLength=fileLoad.length(); String length1=String.valueOf(fileLength); response.setHeader("Content_Length",length1); FileInputStream in=new FileInputStream(fileLoad); int n; while((n=in.read(b))!=-1){    o.write(b,0,n); } in.close(); out.clear(); out = pageContext.pushBody(); %>

转载:http://blog.csdn.net/z69183787/article/details/12995451

转载于:https://www.cnblogs.com/zhengjian6797/p/4565634.html

你可能感兴趣的文章
SQL Server 2012 AlwaysOn高可用配置之六:启用AlwaysOn功能
查看>>
HL7标准V3开发框架中个模型的关系
查看>>
hash 散列生成目录
查看>>
开通博客的第一天
查看>>
密码权限管理
查看>>
Hive(一):Hive的安装部署
查看>>
Tomcat9 多端口 多项目
查看>>
raid+lvm+quota 实现流程
查看>>
linux tomcat配置https
查看>>
史上最牛最详细的Linux教程 不看后悔终生!
查看>>
极快的正整数排序函数
查看>>
setfacl
查看>>
web防火墙
查看>>
windows 2003 ×××的建立
查看>>
资料库保存树结构的三种方法
查看>>
iPhone开发之NSNotificationCenter(通知)的使用方法
查看>>
使用fpm来定制rpm包第一步----如何在CentOS7上安装fpm
查看>>
一句话总结BGP特性
查看>>
回首向来萧瑟处,归去,也无风雨也无晴 — call、apply和bind
查看>>
MySQL的mysqldump工具的基本用法
查看>>