java通用下载
在下载方法之前先认识一下IO流中的方法:
关于.read()方法的解析
-
read():
1.从读取流读取的是一个一个字节
2.返回的是字节的(0-255)内的字节值
3.读一个下次就自动到下一个,如果碰到-1说明没有值了.
-
read(byte[] bytes)
1.从读取流读取一定数量的字节,如果比如文件总共是102个字节
2.我们定义的数组长度是10,那么默认前面10次都是读取10个长度
3.最后一次不够十个,那么读取的是2个
4.这十一次,每次都是放入10个长度的数组.
-
read(byte[] bytes,int off ,int len)
- 1.从读取流读取一定数量的字节,如果比如文件总共是102个字节
- 2.我们定义的数组长度是10,但是这里我们写read(bytes,0,9)那么每次往里面添加的(将只会是9个长度),就要读12次,最后一次放入3个.
- 3.所以一般读取流都不用这个而是用上一个方法:read(byte[]);
关于write()方法的解析
-
write(byte[] bytes);
往流里边写入缓冲字节数组中的所有内容,不满整个数组长度的”空余内容”也会加入,这个下面重点讲,
-
write(byte[] bytes,int off,int len);
1.这个是更严谨的写法,在外部定义len,然后每次len(为的是最后一次的细节长度)都等于流往数组中存放的长度
2.如上述read(bytes),前面每次都放入十个,第十一次放入的是2个,如果用第二种write(bytes),将会写入输出流十一次,每次写入十个长度,造成后面有8个空的,比原来的内容多了
3.所以用write(byte[] bytes,int off,int len);就不会出现多出来的空的情况,因为最后一次len不同
-
下面是下载方法的具体实现代码
在java中调用reponse.getOutputStream()方法会自动激活下载操作
public static void download(String fileName, String filePath,HttpServletRequest
request,HttpServletResponse response)
throws Exception {
//声明本次下载状态的记录对象
DownloadRecord downloadRecord = new DownloadRecord(fileName, filePath, request);
//设置响应头和客户端保存文件名
response.setCharacterEncoding("utf-8");
response.setContentType("multipart/form-data");
response.setHeader("Content-Disposition", "attachment;fileName=" + fileName);
//用于记录以完成的下载的数据量,单位是byte
long downloadedLength = 0l;
try {
//打开本地文件流
InputStream inputStream = new FileInputStream(filePath);
//激活下载操作
OutputStream os = response.getOutputStream();
//循环写入输出流
byte[] b = new byte[2048];
int length;
while ((length = inputStream.read(b)) > 0) {
os.write(b, 0, length);
downloadedLength += b.length;
}
// 关闭。
os.close();
inputStream.close();
} catch (Exception e){
downloadRecord.setStatus(DownloadRecord.STATUS_ERROR);
throw e;
}
downloadRecord.setStatus(DownloadRecord.STATUS_SUCCESS);
downloadRecord.setEndTime(new Timestamp(System.currentTimeMillis()));
downloadRecord.setLength(downloadedLength);
//存储记录
}