我将图像作为BLOB存储在数据库中。现在我可以使用Richfaces mediaOutput标签在我的jsf页面中显示它们。
当图像存储在数据库中时,图像是否可以包含“/images/image.jpg”之类的路径。
在寻找答案时,我遇到了类似的事情:
@GET
@Path("/files/{filename}")
@Produces(MediaType.WILDCARD)
祝你好运, 伊利亚西多罗维奇
答案 0 :(得分:4)
您可以编写一个servlet来获取/image/*
的每个请求或适合您的内容。
在servlet中,您可以通过请求参数从数据库中检索正确的数据。
你通过
response.getOutputStream().write(content);
(内容是你图像的字节)
答案 1 :(得分:1)
谢谢roel和BalusC!
如果有人遇到这个问题,可以采取以下措施。
package org.gicm.test;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.inject.Inject;
import java.io.BufferedOutputStream;
import java.io.BufferedInputStream;
import org.gicm.cms.CMSDao;
import org.gicm.model.UploadedImage;
@WebServlet("/images/*")
public class TestServlet extends HttpServlet {
@Inject
private CMSDao cms;
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String imageId = String.valueOf(request.getPathInfo().substring(1)); // Gets string that goes after "/images/".
UploadedImage image = cms.findImage(imageId); // Get Image from DB.
response.setHeader("Content-Type", getServletContext().getMimeType(image.getName()));
response.setHeader("Content-Disposition", "inline; filename=\"" + image.getName() + "\"");
BufferedInputStream input = null;
BufferedOutputStream output = null;
try {
input = new BufferedInputStream(image.getData()); // Creates buffered input stream.
output = new BufferedOutputStream(response.getOutputStream());
byte[] buffer = new byte[8192];
for (int length = 0; (length = input.read(buffer)) > 0;) {
output.write(buffer, 0, length);
}
} finally {
if (output != null) try { output.close(); } catch (IOException logOrIgnore) {}
if (input != null) try { input.close(); } catch (IOException logOrIgnore) {}
}
}
}