使用Response实现下载文件,浏览器并没有弹出文件保存框

使用Response实现下载文件,浏览器并没有弹出文件保存框


文件下载类是这样的:

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import javax.servlet.http.HttpServletResponse;
/**
 * 文件上传下载工具
 * @author jwj
 */
public class FileUtil {
	/**
	 * 远程文件下载
	 * @param filePath	远程文件的url
	 * @param response
	 */
	public static void remoteFileDownload(String filePath,HttpServletResponse response) {
		OutputStream outputStream = null;
		InputStream inputStream = null;
		URL url;
		try {
			url = new URL(filePath);
			HttpURLConnection conn = (HttpURLConnection) url.openConnection();//利用HttpURLConnection对象,我们可以从网络中获取网页数据.
            conn.setDoInput(true);
            conn.connect();
            int contentLength = conn.getContentLength();
            inputStream = conn.getInputStream();
         // 写明要下载的文件的大小
         	response.setContentLength(contentLength);
         	response.setHeader("Content-Disposition", "attachment;filename="+ filePath);// 设置在下载框默认显示的文件名
         	response.setContentType("application/octet-stream");// 指明response的返回对象是文件流
			outputStream = response.getOutputStream();
			
			byte[] buf = new byte[1024];
			int len = 0;
			while((len = inputStream.read(buf))!=-1) {
				outputStream.write(buf,0,len);
			}

		} catch (IOException e) {
			e.printStackTrace();
		}finally {
			try {
				if(outputStream !=null) {
					outputStream.close();
				}
				if(inputStream != null) {
					inputStream.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}
}

使用的地址访问是可以出现下载的,但是在js中用ajax做请求时,返回的request headers都正常,但就是不出现下载;
最后得知:js的ajax函数的返回类型只有xml、text、json、html等类型,没有“流”类型,所以我们要实现ajax下载,不能够使用相应的ajax函数进行文件下载。但可以用js生成一个form,==用这个form提交参数,并返回“流”类型的数据。==在实现过程中,页面也没有进行刷新。

  • 7
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现文档填充并下载多个文件,可以按照以下步骤进行: 1. 使用Java POI库创建模板文件和填充数据 2. 将填充后的模板文件保存到服务器上的指定位置 3. 使用Java Servlet编写一个下载文件的接口,实现文件下载 4. 在前端页面上添加下载按钮,调用下载接口下载多个文件 下面是一个简单的实现示例: 1. 创建模板文件和填充数据 假设我们有两个需要填充数据的模板文件,一个是word文档,一个是excel表格。我们可以使用Java POI库来创建这些模板文件,并将数据填充到模板文件中。具体代码如下: ```java // 创建word文档模板并填充数据 XWPFDocument doc = new XWPFDocument(new FileInputStream("template.docx")); Map<String, Object> data = new HashMap<>(); data.put("name", "张三"); data.put("age", 30); doc = WordUtils.fillDocWithData(doc, data); // 创建excel表格模板并填充数据 XSSFWorkbook workbook = new XSSFWorkbook(new FileInputStream("template.xlsx")); Sheet sheet = workbook.getSheetAt(0); Map<String, Object> data2 = new HashMap<>(); data2.put("name", "李四"); data2.put("age", 25); workbook = ExcelUtils.fillWorkbookWithData(workbook, sheet, data2); ``` 2. 保存填充后的模板文件到服务器 ```java // 保存填充后的word文档到服务器 FileOutputStream out = new FileOutputStream("filled.docx"); doc.write(out); out.close(); // 保存填充后的excel表格到服务器 FileOutputStream out2 = new FileOutputStream("filled.xlsx"); workbook.write(out2); out2.close(); ``` 3. 编写下载文件的接口 我们可以使用Java Servlet来实现下载多个文件的接口。具体代码如下: ```java @WebServlet("/download") public class DownloadServlet extends HttpServlet { protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取需要下载文件名列表 String[] fileNames = request.getParameterValues("fileName"); // 设置响应头,告诉浏览器下载文件 response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("files.zip", "UTF-8")); // 创建zip压缩文件 ZipOutputStream zipOut = new ZipOutputStream(response.getOutputStream()); for (String fileName : fileNames) { // 将指定文件添加到zip压缩文件中 File file = new File(fileName); FileInputStream in = new FileInputStream(file); zipOut.putNextEntry(new ZipEntry(file.getName())); byte[] buffer = new byte[1024]; int len; while ((len = in.read(buffer)) > 0) { zipOut.write(buffer, 0, len); } zipOut.closeEntry(); in.close(); } zipOut.flush(); zipOut.close(); } } ``` 4. 在前端页面上添加下载按钮 在前端页面上添加一个下载按钮,并在点击按钮时调用下载接口,传递需要下载文件名列表即可。具体代码如下: ```html <button onclick="downloadFiles()">下载文件</button> <script> function downloadFiles() { var fileNames = ["filled.docx", "filled.xlsx"]; var url = "/download?fileName=" + fileNames.join("&fileName="); window.open(url); } </script> ``` 这样,当用户点击下载按钮时,浏览器弹出下载对话,用户可以选择保存多个文件到本地。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值