文件流下载总有额外内容

chen870201 2010-10-22 12:11:48
我们的框架是JSF 1.1
最近在做下载,文件放到服务器上的某文件夹内,客户端请求后,程序用流的方式读取文件并输出到客户端
需要做到模拟传统JSP那种发送一个URL请求或跳转到该URL,根据传值自动下载

但是在实际应用中,发现以下问题:
1)使用一个纯的JSP页面,下载Word、Excel文件乱码,文件名正常;下载txt文件不乱码,但是最上面会多一个空行;
2)写一个JSF的bean绑定到CommandButton上,点击这个Button则下载的文件正确;
3)将该方法写到bean中的Getter方法中,能实现请求该页面就自动下载文件,但是则下载到的文件仍是乱码,而且强制打开Excel文件会发现最后有<html><head>……这样的Html代码


JSF页面调用的方法如下:

/**
* <p>
* 功能说明:将服务器上的文件下载到本地 文件名为原文件名
* </p>
*
* @param strfileName String 处理得到的文件URL+实际文件名
* @param S_Name String 原文件名
* @return void
* @throws IOException
*/
public static void downloadFileAsS_Name(String strfileName,String S_Name) throws IOException {
File exportFile = new File(strfileName);
try {
exportFile = FileEncrypt.dencrypt(exportFile); //解密
HttpServletResponse httpServletResponse = (HttpServletResponse)
FacesContext.getCurrentInstance().getExternalContext().getResponse();
ServletOutputStream servletOutputStream = httpServletResponse.getOutputStream();
// 此处只写文件名exportFile.getName(),不需绝对路径

httpServletResponse.setHeader( "Content-Disposition",
"attachment;filename=" + new String(S_Name.getBytes("gb2312"),"ISO8859-1"));
httpServletResponse.setContentLength((int) exportFile.length());
httpServletResponse.setContentType("application/x-download");

byte[] b = new byte[1024];
int i = 0;
FileInputStream fis = new java.io.FileInputStream(exportFile);
while ((i = fis.read(b)) > 0) {
servletOutputStream.write(b, 0, i);
}
fis.close();
} catch (IOException e) {
e.printStackTrace();
logger.error(e);
throw e;
} catch (Exception e) {
e.printStackTrace();
}
exportFile.delete();
FacesContext.getCurrentInstance().responseComplete();
}



将以上代码放入JSP页面,稍作修改:httpServletResponse改为response,该页面也能实现下载但是乱码

请各位帮忙分析下
google网上的说法,一般是说页面请求的编码格式、文件类型注册这两种问题,我都避免了
因为JSF手工点击是能够实现下载的

...全文
180 2 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
空心兜兜 2010-10-22
  • 打赏
  • 举报
回复
谢谢,这个我加了,还是一样啊
不知为什么
Jacy_Young 2010-10-22
  • 打赏
  • 举报
回复
在 web.xml 里面 加上 下面这段配置代码 试下。 应该 可以

<mime-mapping>
<extension>doc</extension>
<mime-type>application/msword</mime-type>
</mime-mapping>
<mime-mapping>
<extension>xls</extension>
<mime-type>application/msexcel</mime-type>
</mime-mapping>
<mime-mapping>
<extension>txt</extension>
<mime-type>application/txt</mime-type>
</mime-mapping>


81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧