<%@ page language="java" import="java.sql.*,java.io.*,java.net.URLDecoder,java.net.URLEncoder"%>
<%@ page contentType="text/html;charset=gb2312"%>
<html>
<body>
<%
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
Connection con = DriverManager.getConnection("jdbc:microsoft:sqlserver://localhost:1444;DatabaseName=jspdev","sa","");
Statement stmt = con.createStatement();
String id=request.getParameter("id");
ResultSet rs = stmt.executeQuery("SELECT filename,content FROM TFILES where id="+id);
// if the resultset is not null
if (rs.next()){
String filename=rs.getString("filename");
response.setHeader("Content-Disposition",
"attachment;filename="+URLEncoder.encode(filename,"UTF-8"));
response.setHeader("Connection", "close");
response.setHeader("Content-Type", "application/octet-stream");
ServletOutputStream sout=response.getOutputStream();
InputStream in = rs.getBinaryStream("content");
byte b[] = new byte[1024*8];
for(int i=in.read(b);i!=-1;)
{
sout.write(b);
i=in.read(b);
}
sout.flush();
sout.close();
in.close();
}
rs.close();
stmt.close();
con.close();
%>
</body>
</html>
本文提供了一个使用Java Web技术实现文件下载功能的例子。通过设置HTTP响应头来触发浏览器下载文件,并利用数据库存储文件内容。该示例适用于希望了解如何在Java Web应用中实现文件上传下载功能的开发者。
1409

被折叠的 条评论
为什么被折叠?



