2008-09-29 8 views
2

Я разрабатываю веб-приложение с использованием Struts 2.1.2 и Hibernate 3.2.6.GA. У меня есть объект, User, который я сопоставил с таблицей USERS в БД, используя Hibernate. Я хочу иметь изображение, связанное с этой сущностью, которую я планирую хранить как BLOB в БД. Я также хочу отображать изображение на веб-странице вместе с другими атрибутами User.Как я могу показывать изображение в браузере с помощью Struts 2 + Hibernate 3?

Решение, которое я мог придумать, состоял в том, чтобы иметь стол IMAGES(ID, IMAGE), где IMAGE - столбец BLOB. USERS будет иметь столбец FK под названием IMAGEID, который указывает на таблицу IMAGES. Затем я буду отображать свойство на объекте User, которое называется imageId, сопоставленное с этим IMAGEID как длинное. При рендеринге страницы с помощью JSP я бы добавил изображения как <img src="images.action?id=1"/> и т. Д., И у вас есть действие, которое считывает изображение и передает содержимое в браузер, при этом заголовки должны кэшировать изображение в течение длительного времени.

Будет ли это работать? Есть ли лучший подход для рендеринга изображений, хранящихся в БД? Сохраняет ли такие изображения в БД правильный подход в первую очередь?

ответ

4

Да, ваше предлагаемое решение будет работать. Учитывая, что вы работаете в среде Java, сохранение изображений в базе данных - лучший способ. Если вы работаете в одной серверной среде с сервером приложений, который позволит вам развернуть в разобранном формате технически, вы можете хранить изображения на диске, но это не будет лучшей практикой. Одним из предложений было бы использовать сервлет вместо JSP. Чтобы получить хорошее поведение в браузере, браузер должен думать, что тип файла, который он отображает, соответствует типу файла, который он ожидает. Несмотря на наличие заголовков типа mime, расширение файла по-прежнему очень важно. Итак, вы хотите ссылку, которая выглядит следующим образом:

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

Где 123456789 первичный ключ вашего изображения в базе данных. Ваше отображение сервлета будет выглядеть следующим образом:

<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> 

Затем сервлет просто разобрать URL запроса для изображения ID, а не с помощью строки запроса в строке запроса будет ввести в заблуждение некоторых браузеров.Использование строки запроса не будет нарушать браузеры напрямую, но вы получите странное поведение в отношении кеширования, и некоторые браузеры могут сообщать о содержании как небезопасное.

0

Если вы хотите отобразить изображение пользователя напрямую со своими свойствами, возможно, вы можете рассмотреть возможность встраивания данных изображения непосредственно в HTML.

Используя специальные данные: схема URL вы можете вставлять любые данные мимические внутри HTML-страницы, формат выглядит следующим образом:

data:<mimetype>;base64,<data> 

потребности быть заменены мима Тип ваших данных (например, image/png) и - это закодированная в base64 строка фактических байтов файла.

См. RFC 2557.

Example:

<img src=""> 
+0

Я просто прочитал, что это не работает с IE, пока не будет выпущена версия 8. Кроме того, изображение не кэшируется в браузере. Поэтому, несмотря на простоту кодирования, я думаю, что буду использовать свою оригинальную схему. – 2008-09-30 03:05:03

+0

также помните, что существует (действительно строгий) предел длины такой строки. От 1 тыс. Символов до 100 тыс. В зависимости от браузера. – 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

Ваше предлагаемое решение будет работать отлично. Я сделал то же самое.

Но для этого вам не нужен сервлет. У Struts2 уже есть результат потока.

См. Это Struts 2 Example, который описывает именно то, что вы хотите.

 Смежные вопросы

  • Нет связанных вопросов^_^