关于下载时遇到的一些问题

公司需要把原本的网络下载改成可控制的限速下载,然后就决定用io流来改。之前有写过io流的下载,但现实情况远比想的复杂于是出了各种问题,下边是我整理的。

1.内存溢出问题(纠结了很久)

下载写好之后有一个现象很奇怪,下载小文件没问题,但大文件会出现内存溢出问题。

错误提示:java.lang.OutOfMemoryError: Java heap space

错误代码 : byte[] buffer = new byte[fis.available()]

分析:读取文件时会把读取到的字节缓存到字节数组中,fis.available()获取的是文件的大小,所以就相当于一次读取完,内存就溢出了

正确代码 :byte[] bytes = new byte[1024];

2.io下载时如果是网络下载,下载地址中文需要转码,不然会乱码

URLEncoder.encode(fileUrl.substring(fileUrl.lastIndexOf("/")+1),"UTF-8");

而本地下载则不需要

3.获取文件名时乱码

String agent = request.getHeader("User-Agent").toLowerCase(); //获取浏览器类型
 String fileName = file.getName();
 if (agent.indexOf("msie") != -1 || (agent.indexOf("rv") != -1 && agent.indexOf("firefox") == -1)) {  
fileName = URLEncoder.encode(fileName, "UTF-8"); //ie浏览器文件名转码
} else {  
fileName = new String(fileName.getBytes("UTF-8"), "ISO8859-1");//非ie浏览器文件名转码

}  

4.获取文件大小时报错(后台打印大小为负)

resp.setContentLength(conn.getContentLength());//网络下载时,只能用该方法获取文件大小,setContentLength()参数为int,如果文件过大就会越界,变成负数

 resp.addHeader("Content-Length", file.length()+"");//通过本地找到文件,直接获取文件大小


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值