I’m using PrimeFaces 3.2 on JBoss 7.1.1.
I am trying to display an image which is stored in a BLOB in a MySQL database in <ui:repeat>. The image is stored in a byte[] and then converted to a StreamedContent as follows:
InputStream stream = new ByteArrayInputStream(ingredient.getImage());
ingredient.setJsfImage(new DefaultStreamedContent(stream, "image/jpg"));
Then I am trying to display it in a Facelet as follows:
<ui:repeat var="ingredient" value="#{formBean.ingredientResultSet}">
<p:panel id="resultsPanel" header="#{ingredient.location.shopName}">
<p:graphicImage value="#{ingredient.jsfImage}" alt="No picture set" />
...
However, when loading the page, I get the following error in JBoss:
SEVERE [org.primefaces.application.PrimeResourceHandler] (http–127.0.0.1-8080-12) Error in streaming dynamic resource.
How is this caused and how can I solve it?
You need to realize that the
<p:graphicImage>actually renders a<img src>element with just an URL which is then later individually invoked by the webbrowser when it’s about to parse the obtained HTML markup and present the results.So, whatever you do in the getter method of
<p:graphicImage>it must be designed that way that it can be invoked on a per-request basis. So, the most sane approach would be to create a<p:graphicImage>with a<f:param>wherein the<p:graphicImage value>points an entirely standalone request or application scoped bean (and thus absolutely not view or session scoped), and the<f:param value>points the unique image identifier.E.g.
Where the
Imagesbacking bean can look like this:Or, if you’re already using OmniFaces 2.0 or newer, then consider using its
<o:graphicImage>instead which can be used more intuitively, almost exectly the way as you expected. See also the blog on the subject.See also: