java浏览器无数据,JAVA实现文件下载,浏览器端失去数据没反应

JAVA实现文件下载,浏览器端得到数据没反应

代码如下

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

//得到要下载的文件名称

String filename=request.getParameter("filename");

//文件存放的路径,合成绝对路径

String dir = this.getServletContext().getRealPath("/");

String filepath=dir+"bksh"+"\\"+filename;

//得到这个文件的对象

File f=new File(filepath);

//response的编码方式为.doc下载

response.setContentType("application/msword");

//写明要下载的文件的大小

response.setContentLength((int)file.length());

//文件名

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

//独处文件的IO流

FileInputStream fis=new FileInputStream(file);

BufferedInputStream buff=new BufferedInputStream(fis);

byte [] b=new byte[1024];//相当读文件的缓存

long k=0;//该值用于计算当前实际下载了多少字节

//response对象得到输出流

OutputStream myout=response.getOutputStream();

//开始循环下载

while(k

int j=buff.read(b,0,1024);

k+=j;

//将b中的数据写到客户端的内存

myout.write(b,0,j);

}

//将写入到客户端的内存的数据,刷新到磁盘

myout.flush();

firbug显示服务器已经返回了数据,但是貌似浏览器不认为它需要下载这些数据。。。

求高人解答,在线等

分享到:

更多

------解决方案--------------------

response.setCharacterEncoding("utf-8");

response.setContentType("multipart/form-data");

String downloadFileName = "";

if (request.getHeader("User-Agent").toUpperCase().indexOf("MSIE") > 0) {

downloadFileName = URLEncoder.encode(fileRealName, "UTF-8");

} else {

downloadFileName = new String(fileRealName.getBytes("UTF-8"), "ISO8859-1");

}

response.setHeader("Content-disposition", "attachment; filename=" + downloadFileName);

------解决方案--------------------

似乎少了这一句:

response.setContentType("multipart/form-data");

------解决方案--------------------

response.setCharacterEncoding("utf-8");

response.setContentType((mimetype != null) ? mimetype : "application/octet-stream");

response.setContentLength(workbook.getBytes().length);

response.setHeader("Content-Disposition", "attachment;filename=" + playdate + ".xls");

------解决方案--------------------

引用:response.setCharacterEncoding("utf-8");

response.setContentType((mimetype != null) ? mimetype : "application/octet-stream");

response.setContentLength(workbook.getBytes().length);

response.setHeader("Content-Disposition", "attachment;filename=" + playdate + ".xls");

唯一的明白人是这个哥们,要下载你得告诉浏览器,而不是发了数据就完事了。

response.setHeader("Content-type", "application-download");

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值