如何使用<p:media>?</p:media>绑定动态内容

时间:2013-01-09 09:47:49

标签: jsf jsf-2 primefaces media dynamic-content

我使用<p:media>显示静态PDF内容。

<p:media value="/resource/test.pdf" 
         width="100%" height="300px" player="pdf">  
</p:media>

如何更改它以显示动态内容?

1 个答案:

答案 0 :(得分:10)

<p:graphicImage>中的一样,value属性可以指向返回StreamedContent的bean属性。这只需要一个特殊的getter方法,原因在下面的答案中有详细解释:<p:graphicImage>使用来自数据库的动态资源:Display dynamic image from database with p:graphicImage and StreamedContent

在您的特定示例中,它看起来像这样:

<p:media value="#{mediaManager.stream}" width="100%" height="300px" player="pdf">
    <f:param name="id" value="#{bean.mediaId}" />
</p:media>

使用

@ManagedBean
@ApplicationScoped
public class MediaManager {

    @EJB
    private MediaService service;

    public StreamedContent getStream() throws IOException {
        FacesContext context = FacesContext.getCurrentInstance();

        if (context.getCurrentPhaseId() == PhaseId.RENDER_RESPONSE) {
            // So, we're rendering the HTML. Return a stub StreamedContent so that it will generate right URL.
            return new DefaultStreamedContent();
        } else {
            // So, browser is requesting the media. Return a real StreamedContent with the media bytes.
            String id = context.getExternalContext().getRequestParameterMap().get("id");
            Media media = service.find(Long.valueOf(id));
            return new DefaultStreamedContent(new ByteArrayInputStream(media.getBytes()));
        }
    }

}