实现方法
Java请求中设置header请求头参数
import java.io.File;
import javax.servlet.http.HttpServletResponse;
public class FileUtil {
public static void fileDownload(HttpServletResponse response, File file) {
FileInputStream fileInputStream = null;
ServletOutputStream outputStream = null;
try {
fileInputStream = new FileInputStream(file);
response.setHeader("content-disposition", "attachment;fileName=" + URLEncoder
.encode(file.getName(), CharsetUtil.UTF_8));
response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
outputStream = response.getOutputStream();
IOUtils.copy(fileInputStream, outputStream);
} catch (Exception e) {
throw new RuntimeException(e);
} finally {
try {
if (outputStream != null) outputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
try {
if (fileInputStream != null) fileInputStream.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
js实现文件流下载处理
axios.post(`请求地址`, 请求需要的数据, {responseType: 'blob'}).then(response => {
let split = response.headers['content-disposition'].split("=");
let fileReader = new FileReader();
fileReader.readAsDataURL(response.data);
fileReader.onload = e => {
let a = document.createElement('a');
a.download = split[1];
a.href = e.target.result;
document.body.appendChild(a);
a.click();
document.body.removeChild(a);
}
})