我正在使用Struts 2.1.2和Hibernate 3.2.6.GA开发Web应用程序。我有一个实体,User,我使用Hibernate映射到数据库中的表USERS。我希望有一个与此实体关联的图像,我打算将其作为BLOB存储在数据库中。我还想在网页上显示图像以及IMAGES(ID, IMAGE)的其他属性。

我能想到的解决方案是有一个表IMAGE,其中FKIMAGEID列。 IMAGES将有一个名为imageId<img src="images.action?id=1"/>列,该列指向<=>表。然后,我将在<=>实体上映射一个属性,称为<=>映射到此<=>为Long。使用JSP渲染页面时,我会将图像添加为<=>等,并有一个Action来读取图像并将内容流式传输到浏览器,标题设置为长时间缓存图像。

这会有用吗?有没有更好的方法来渲染存储在数据库中的图像?首先在DB中存储这样的图像是正确的方法吗?

有帮助吗?

解决方案

是的,您建议的解决方案可行。鉴于您正在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,而不是使用查询字符串,因为查询字符串会混淆某些浏览器。使用查询字符串不会彻底破坏浏览器,但是你会得到关于缓存的奇怪行为,而某些浏览器可能会将内容报告为不安全。

其他提示

Internet Explorer不支持该图像嵌入样式。

如果您想直接使用其属性显示用户图像,可以考虑直接在HTML中嵌入图像数据。

使用特殊数据:URL方案,您可以在HTML页面中嵌入任何mime数据,格式如下:

data:<mimetype>;base64,<data>

需要替换为数据的mime类型(例如image / png)和 是文件实际字节的base64编码字符串。

请参阅 RFC 2557

示例

<img src="">

您建议的解决方案可以完美运行。我做了同样的事情。

但是你不需要这个servlet。 Struts2已经有了一个流结果。

请参阅 Struts 2示例,其中详细描述了您的需求。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top