先说原因:
因为是引用了Jquery mobile + jsp的方式做的页面,代码<a href="downloadfile?downloadFileName=F:/a.jpg" target="_top">下载user</a> 怎么执行都是错误的(代码里面的downloadFileName是java servlet)。换成普通的jsp下载代码,如下:
<%@page language="java" contentType="application/x-msdownload" pageEncoding="gb2312"%><%
//关于文件下载时采用文件流输出的方式处理:
//加上response.reset(),并且所有的%>后面不要换行,包括最后一个;
response.reset();//可以加也可以不加
response.setContentType("application/x-download");
String filedownload = "想办法找到要提供下载的文件的物理路径+文件名";
String filedisplay = "给用户提供的下载文件名";
filedisplay = URLEncoder.encode(filedisplay,"UTF-8");
response.addHeader("Content-Disposition","attachment;filename=" + filedisplay);
OutputStream outp = null;
FileInputStream in = null;
try
{
outp = response.getOutputStream();
in = new FileInputStream(filenamedownload);
byte[] b = new byte[1024];
int i = 0;
while((i = in.read(b)) > 0)
{
outp.write(b, 0, i);
}
outp.flush();
}
catch(Exception e)
{
System.out.println("Error!");
e.printStackTrace();
}
finally
{
if(in != null)
{
in.close();
in = null;
}
if(outp != null)
{
outp.close();
outp = null;
}
}
%>
结果还是错误。页面总是返回UNDEFINED,之后刷新页面才显示文件下载对话框。
查询百度,都说要增加
- out.clear();
- out = pageContext.pushBody();
但是即使增加了也没有用,还是返回UNDEINFED,之后需要刷新才显示下载对话框。最后排查,发现删除<script src="jquery-mobile/jquery.mobile-1.0.min.js" type="text/javascript"></script>代码就正常,加上就不对。
原来
jquery mobile使用a标签跳转页面时页面未执行pageinit事件,就是这个带来问题。
解决办法:在a标签中设置属性值,target="_top",然后跳转的页面页面初始化事件中的代码就执行啦。
查html文档,一下描述
_top
这个目标使得文档载入包含这个超链接的窗口,用 _top 目标将会清除所有被包含的框
架并将文档载入整个浏览器窗口。
也就是说设置这个属性后,强制性将文档清空并加载了一次,所以解决了那个问题。