问题:如果记录数量很大,CSV 文件的内容将显示为页面内容。
预期:文件下载。
通过 window.open(url) 从另一个页面触发请求;以下是 url 处理程序。
@RequestMapping(value = "/url", method = RequestMethod.GET)
public void handler(HttpServletRequest request,ModelMap map, @RequestParam("itemPk") long pk, HttpServletResponse response) throws Exception {
CSVWriter csvWriter = new CSVWriter(new OutputStreamWriter(response.getOutputStream()));
try {
List<String[]> data = new ArrayList<String[]>();
for (int i = 0; i < 500; i++) {
String[] row = new String[] {"asdr", "10", "sourajit", "34.567", "06-DEC-2015", "awx445"};
data.add(row);
}
csvWriter.writeAll(data);
response.setContentType("text/csv");
response.setHeader("Content-disposition", "attachment; filename=volcs.csv");
} finally {
csvWriter.flush();
csvWriter.close();
}
}
GET 或 POST 的行为相同。 (对于 POST,使用 html 表单打开一个新窗口)
最佳答案
这是因为 Writer 实例用于生成响应。
我们需要将其视为字节。
ServletOutputStream out = response.getOutputStream();
out.write(baos.toByteArray());
baos.writeTo(out);
out.flush();
关于java - csv 文件的内容显示在网页上,而不是正确的文件下载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37586080/