2008-09-29 87 views
2

我正在開發一個使用Struts 2.1.2和Hibernate 3.2.6.GA的Web應用程序。我有一個實體User,我使用Hibernate將其映射到DB中的表USERS。我想要一個與此實體關聯的圖像,我打算在數據庫中將其存儲爲BLOB。我也想在網頁上顯示圖片以及User的其他屬性。如何使用Struts 2 + Hibernate 3將圖像提供給瀏覽器?

我能想到的解決方案是有一個表IMAGES(ID, IMAGE)其中IMAGEBLOB列。 USERS將有一個FK列名爲IMAGEID,它指向IMAGES表。然後我將映射User實體上的一個屬性,名爲imageId作爲一個Long映射到這個IMAGEID。當使用JSP呈現頁面時,我會將圖像添加爲<img src="images.action?id=1"/>等,並且具有一個Action,它讀取圖像並將內容流式傳輸到瀏覽器,同時將頭部設置爲緩存圖像很長時間。

這項工作?渲染存儲在數據庫中的圖像是否有更好的方法?首先將這些圖像存儲在數據庫中是否正確?

回答

4

是的,你的建議解決方案將工作。鑑於您正在Java環境中工作,將圖像存儲在數據庫中是最佳途徑。如果您正在單個服務器環境中運行應用程序服務器,該服務器可讓您以技術方式以分解格式進行部署,則可以將這些映像存儲在磁盤上,但這不是最佳做法。一個建議是使用servlet而不是JSP。爲了獲得良好的瀏覽器行爲,您希望瀏覽器認爲它所顯示的文件類型與它所期望的文件類型相匹配。儘管存在MIME類型頭文件,文件擴展名仍然非常重要。因此,您需要一個如下所示的鏈接:

<a href="foo.jsp"><img src="imageservlet/123456789.png"></a> 

其中,123456789是圖像在數據庫中的主鍵。你的servlet映射是這樣的:

<servlet> 
    <servlet-name>ImageServlet</servlet-name> 
    <servlet-class>com.example.ImageServlet</servlet-class> 
</servlet> 
<servlet-mapping> 
    <servlet-name>ImageServlet</servlet-name> 
    <url-pattern>/imageservlet/*</url-pattern> 
</servlet-mapping> 

然後在你的servlet簡單解析爲圖像ID請求的URL,而不是使用查詢字符串作爲查詢字符串會混淆一些瀏覽器。使用查詢字符串不會直接破壞瀏覽器,但是在緩存方面您會遇到奇怪的行爲,並且某些瀏覽器可能會將內容報告爲不安全。

0

如果您想直接用它們的屬性顯示用戶圖像,也許可以考慮直接在HTML中嵌入圖像數據。

使用特殊的數據:URL方案您可以嵌入HTML頁面內的任何MIME數據,格式如下:

data:<mimetype>;base64,<data> 

需要由MIME代替類型的數據(例如圖像/ PNG)和 是文件實際字節的base64編碼字符串。

請參閱RFC 2557

Example

<img src=""> 
+0

我剛剛讀到,這不適用於IE,直到版本8發佈。此外,圖像不會在瀏覽器上緩存。所以,儘管編碼方便,我想我會使用我原來的方案。 – 2008-09-30 03:05:03

+0

還記得對這種字符串的長度有一個(非常嚴格的)限制。從1k字符到100k取決於瀏覽器。 – 2011-12-28 14:33:24

0

Internet Explorer不支持圖像嵌入的那種風格。

+0

剛剛測試過http://rifers.org/blogs/gbevin/2005/4/11/embedding_images_inside_html與IE7,它工作得很好。 – 2008-09-29 23:18:21

0

您的建議解決方案將完美運作。我做了同樣的事情。

但是你不需要一個servlet。 Struts2已經有一個流結果。

看到這個Struts 2 Example它確切地描述你想要的。

相關問題