[英]How to display images from database in JSF
我有圖像作為BLOB存儲在數據庫中。 現在我可以使用Richfaces mediaOutput標簽在我的jsf頁面中顯示它們。
當圖像存儲在數據庫中時,圖像是否可能具有類似“/images/image.jpg”的路徑。
在尋找答案時,我遇到了類似這樣的事情:
@GET
@Path("/files/{filename}")
@Produces(MediaType.WILDCARD)
最誠摯的問候,Ilya Sidorovich
您可以編寫一個servlet來獲取/image/*
或適合您的任何請求。 在servlet中,您可以通過請求參數從數據庫中檢索正確的數據。 你通過寫出數據
response.getOutputStream().write(content);
(內容是你圖像的字節)
謝謝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) {}
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.