<%@ page contentType="text/html;charset=gb2312" %>
<html>
<%@ page import="java.io.*,mail.util.Encoding" %>
<jsp:useBean id="mySmartUpload" scope="page" class="com.jspsmart.upload.SmartUpload" />
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>
<body>
<%
String filename =Encoding.encodingUnicode(request.getParameter("filename"));
mail.DbBase dbbase=mail.DbBase.getInstance();
String path=dbbase.getPath();
// 初始化
mySmartUpload.initialize(pageContext);
// 设定contentDisposition为null以禁止浏览器自动打开文件,
//保证点击链接后是下载文件。若不设定,则下载的文件扩展名为
//doc时,浏览器将自动用word打开它。扩展名为pdf时,
//浏览器将用acrobat打开。
mySmartUpload.setContentDisposition(null);
// 下载文件
if(filename!=null){
mySmartUpload.downloadFile(path+filename);
}
%>
</body>
</html>
执行下载时,文件能正确下载,但是总是报错。
java.lang.IllegalStateException: getOutputStream() has already been called for this response
后来还才发现,执行下载的页面,在Java脚本范围外(即<% ...%>之外),不要包含HTML代码、空格、回车或换行等字符,有的话将不能正确下载。不信的话,可以在上述源码中%><%之间加入一个换行符,再下载一下,保证出错。因为它影响了返回给浏览器的数据流,导致解析出错。
修改后问题解决。