in app/src/main/java/org/apache/roller/weblogger/ui/rendering/servlets/MediaResourceServlet.java [65:162]
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
MediaFileManager mfMgr = WebloggerFactory.getWeblogger()
.getMediaFileManager();
Weblog weblog;
WeblogMediaResourceRequest resourceRequest;
try {
// parse the incoming request and extract the relevant data
resourceRequest = new WeblogMediaResourceRequest(request);
weblog = resourceRequest.getWeblog();
if (weblog == null) {
throw new WebloggerException("unable to lookup weblog: "
+ resourceRequest.getWeblogHandle());
}
} catch (Exception e) {
// invalid resource request or weblog doesn't exist
log.debug("error creating weblog resource request", e);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
long resourceLastMod;
InputStream resourceStream = null;
MediaFile mediaFile;
try {
mediaFile = mfMgr.getMediaFile(resourceRequest.getResourceId(),
true);
resourceLastMod = mediaFile.getLastModified();
} catch (Exception ex) {
// still not found? then we don't have it, 404.
log.debug("Unable to get resource", ex);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
// Respond with 304 Not Modified if it is not modified.
if (ModDateHeaderUtil.respondIfNotModified(request, response,
resourceLastMod, resourceRequest.getDeviceType())) {
return;
} else {
// set last-modified date
ModDateHeaderUtil.setLastModifiedHeader(response, resourceLastMod,
resourceRequest.getDeviceType());
}
// set the content type based on whatever is in our web.xml mime defs
if (resourceRequest.isThumbnail()) {
response.setContentType("image/png");
try {
resourceStream = mediaFile.getThumbnailInputStream();
} catch (Exception e) {
if (log.isDebugEnabled()) {
log.debug(
"ERROR loading thumbnail for " + mediaFile.getId(),
e);
} else {
log.warn("ERROR loading thumbnail for " + mediaFile.getId());
}
}
}
if (resourceStream == null) {
response.setContentType(mediaFile.getContentType());
resourceStream = mediaFile.getInputStream();
}
OutputStream out;
try {
// ok, lets serve up the file
byte[] buf = new byte[RollerConstants.EIGHT_KB_IN_BYTES];
int length;
out = response.getOutputStream();
while ((length = resourceStream.read(buf)) > 0) {
out.write(buf, 0, length);
}
// close output stream
out.close();
} catch (Exception ex) {
log.error("ERROR", ex);
if (!response.isCommitted()) {
response.reset();
response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
}
} finally {
// make sure stream to resource file is closed
resourceStream.close();
}
}