My favorites | Sign in
Project Home Downloads Wiki Issues Source
Checkout   Browse   Changes    
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
* Copyright 2011 stanislawbartkowski@gmail.com
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/

package com.ibm.sampledb.server;

import java.io.BufferedOutputStream;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.activation.MimetypesFileTypeMap;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.support.lob.DefaultLobHandler;
import org.springframework.jdbc.support.lob.LobHandler;

import com.google.gwt.user.server.rpc.RemoteServiceServlet;
import com.ibm.sampledb.shared.IResourceType;
import com.ibm.sampledb.shared.OneRecord;

@SuppressWarnings("serial")
public class DownloadFile extends RemoteServiceServlet {

class RecordMapper implements RowMapper<OneRecord> {

private LobHandler lobHandler = new DefaultLobHandler();
private final HttpServletResponse response;

RecordMapper(HttpServletResponse response) {
this.response = response;
}

@Override
public OneRecord mapRow(ResultSet arg0, int arg1) throws SQLException {
String filename = arg0.getString(1);
MimetypesFileTypeMap mim = new MimetypesFileTypeMap();
String e = mim.getContentType(new File(filename));
response.setContentType(e);
response.setHeader("Content-Disposition", "attachment; filename=\""
+ filename + '\"');
InputStream input = lobHandler.getBlobAsBinaryStream(arg0, 2);
byte[] buffer = new byte[8192];
int size = 0;
int len;
try {
BufferedOutputStream output = new BufferedOutputStream(
response.getOutputStream());
while ((len = input.read(buffer)) != -1) {
size += len;
output.write(buffer, 0, len);
}
output.close();
input.close();
} catch (IOException e1) {
e1.printStackTrace();
throw new SQLException();
}
response.setHeader("Content-Length", "" + size);
return null;
}
}

protected void doGet(HttpServletRequest request,
HttpServletResponse response) throws ServletException, IOException {
// String filename = URLDecoder.decode(request.getPathInfo(), "UTF-8");
try {
String fileid = request.getParameter(IResourceType.ATTACHID);
Integer id = new Integer(fileid);
JdbcTemplate jdbc = GetResourceFile.getJDBC();
String query = GetResourceFile.getSql("getblob.sql");
@SuppressWarnings("unused")
OneRecord o = jdbc.queryForObject(query,
new RecordMapper(response), new Object[] { id });
} catch (Exception e) {
e.printStackTrace();
PrintWriter out = response.getWriter();
out.println(IResourceType.ERRORSUBMIT);
out.close();
}
}
}

Change log

r407 by stanislawbartkowski on Jul 6, 2011   Diff
new version with attachments
Go to: 
Project members, sign in to write a code review

Older revisions

All revisions of this file

File info

Size: 3409 bytes, 103 lines

File properties

svn:mime-type
text/plain
Powered by Google Project Hosting