现在项目下载有两种方式一种是弹出下载对话框然后保存到本地,另外一种是直接弹出ie直接没有对话窗口直接在ie内打开文件。
第一种:弹出下载对话框然后保存到本地
response设置header的地方,设置attachment。
在extjs中代码:
这样就会弹出对话框问保存或者取消。
第二种:新弹出ie页面直接打开文件。
response设置header的地方,设置inline。
在extjs中代码:
这样就会弹出新的页面没有询问框直接打开文件。
小宝制造。
第一种:弹出下载对话框然后保存到本地
//读取pdf输出流
ByteArrayOutputStream ba = priceChartPDF.getPdf();
// 取得输出流
ServletOutputStream outputStream = response.getOutputStream();
//response信息的设置
response.reset();
response.setContentType("application/pdf");
//导出PDF名称
String fileName = "价格数据分析结果报表";
response.setHeader("Content-Disposition", "attachment; filename=\""
+ new String(fileName.getBytes("gb18030"), "ISO8859-1") + ".pdf" + "\"");
response.setContentLength(ba.size());
ba.writeTo(outputStream);
// 刷新输出流
outputStream.flush();
// 关闭输出流
outputStream.close();
response设置header的地方,设置attachment。
在extjs中代码:
{
text: ' 导出',
tooltip: '导出社会库存分析结果',
iconCls: 'export',
ref: '../uploadButton',
formBind: true,
handler: function(){
window.location.href = "xxx/getXxx?district_code=" + district_code;
}
}
这样就会弹出对话框问保存或者取消。
第二种:新弹出ie页面直接打开文件。
//读取pdf输出流
ByteArrayOutputStream ba = customChartPDF.getPdf();
// 取得输出流
ServletOutputStream outputStream = response.getOutputStream();
//response信息的设置
response.reset();
response.setContentType("application/pdf");
//导出PDF名称
String fileName = "客户数据分析结果报表";
response.setHeader("Content-Disposition", "inline; filename=\""
+ new String(fileName.getBytes("gb18030"), "ISO8859-1") + ".pdf" + "\"");
response.setContentLength(ba.size());
ba.writeTo(outputStream);
// 刷新输出流
outputStream.flush();
// 关闭输出流
outputStream.close();
response设置header的地方,设置inline。
在extjs中代码:
{
text: ' 导出',
tooltip: '导出客户数据分析结果',
iconCls: 'export',
ref: '../uploadButton',
formBind: true,
handler: function(){
window.open("xxx/getXxx?district_code="+district_code);
}
}
这样就会弹出新的页面没有询问框直接打开文件。
小宝制造。