2008-09-29 7 views
2

Je développe une application web en utilisant Struts 2.1.2 et Hibernate 3.2.6.GA. J'ai une entité, User, que j'ai mappée à une table USERS dans la base de données en utilisant Hibernate. Je veux avoir une image associée à cette entité, que je prévois de stocker comme BLOB dans la base de données. Je veux également afficher l'image sur une page Web avec d'autres attributs du User.Comment puis-je diffuser une image sur le navigateur en utilisant Struts 2 + Hibernate 3?

La solution que je pouvais penser était d'avoir une table IMAGES(ID, IMAGE)IMAGE est une colonne BLOB. USERS aura une colonne FK appelée IMAGEID, qui pointe vers la table IMAGES. Je vais ensuite mapper une propriété sur l'entité User, appelée imageId mappée à cette IMAGEID en tant que Long. Lors du rendu de la page avec une JSP, j'ajouterais des images comme <img src="images.action?id=1"/> etc., et j'ai une action qui lit l'image et transmet le contenu au navigateur, avec les en-têtes définis pour mettre l'image en cache pendant une longue période.

Est-ce que cela fonctionnera? Existe-t-il une meilleure approche pour le rendu des images stockées dans une base de données? Est-ce que le stockage de telles images dans le DB est la bonne approche?

Répondre

4

Oui, la solution suggérée fonctionnera. Étant donné que vous travaillez dans un environnement Java, le stockage des images dans la base de données est la meilleure solution. Si vous exécutez dans un environnement de serveur unique avec un serveur d'applications qui vous permettra de déployer dans un format éclaté techniquement, vous pouvez stocker les images sur le disque, mais ce ne serait pas la meilleure pratique. Une suggestion serait d'utiliser une servlet au lieu d'une JSP. Pour obtenir un bon comportement du navigateur, vous voulez que le navigateur pense que le type de fichier affiché correspond au type de fichier attendu. Malgré l'existence d'en-têtes de type mime, l'extension de fichier est toujours très importante. Donc, vous voulez un lien qui ressemble à ceci:

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

Où 123456789 est la clé primaire de votre image dans la base de données. Votre mappage de servlet ressemblerait à ceci:

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

Ensuite, dans votre servlet Parse simplement l'URL de demande de l'ID d'image plutôt que d'utiliser la chaîne de requête comme la chaîne de requête confondra certains navigateurs.L'utilisation de la chaîne de requête ne casse pas les navigateurs, mais vous aurez un comportement étrange en ce qui concerne la mise en cache et certains navigateurs peuvent signaler que le contenu est dangereux.

+0

J'ai implémenté ceci en utilisant ce mécanisme (en utilisant une action ServletResponseAware au lieu d'une servlet). Je ne considère pas cela comme une réponse acceptée en espérant que d'autres mécanismes pourraient être mis en place. J'ai upvoted ceci, de sorte que c'est la réponse la plus connue à ce jour. –

0

Si vous souhaitez afficher directement l'image de l'utilisateur avec ses propriétés, vous pouvez peut-être envisager d'incorporer les données de l'image directement dans le code HTML.

En utilisant un ensemble de données spéciales: schéma d'URL que vous êtes en mesure d'intégrer toutes les données mime dans une page HTML, le format est le suivant:

data:<mimetype>;base64,<data> 

doit être remplacé par le mime -type de vos données (image/png par exemple) et est la chaîne codée en base64 des octets réels du fichier.

Voir RFC 2557.

Example:

<img src=""> 
+0

Je viens de lire que cela ne fonctionne pas avec IE, jusqu'à ce que la version 8 soit publiée. En outre, l'image n'est pas mise en cache sur le navigateur. Donc, malgré la facilité de codage, je pense que je vais utiliser mon schéma d'origine. –

+0

n'oubliez pas qu'il existe une limite (vraiment stricte) sur la longueur d'une telle chaîne. De 1k caractères à 100k selon le navigateur. –

0

Internet Explorer ne supporte pas ce style de plongement d'image.

+0

Juste testé http://rifers.org/blogs/gbevin/2005/4/11/embedding_images_inside_html avec IE7 et cela fonctionne très bien. –

+0

L'image dans la publication de Geert n'apparaît pas sur IE6/WinXP. –

0

Votre solution suggérée fonctionnerait parfaitement. J'ai fait la même chose.

Mais vous n'avez pas besoin de servlet pour cela. Struts2 a déjà un résultat de flux.

Voir ce Struts 2 Example qui décrit exactement ce que vous voulez.

Questions connexes