如何正确使用a4j:mediaOutput显示图像?

时间:2011-10-06 16:07:27

标签: java jsf richfaces

使用下面的代码我无法在网页中获取图像。我不确定我是否以正确的方式理解文档,并且我无法找到此代码的任何问题。

BEAN

@ManagedBean(name = "imageBean")
@RequestScoped
public class ImageBean {
    public void paint(OutputStream os, Object data) throws IOException {
        BinaryContent content = (BinaryContent) data;
        BufferedImage image = ImageIO.read(new ByteArrayInputStream(content.getContent()));
        ImageIO.write(image, "jpg", os);
    }
}

PAGE

<rich:dataTable value="#{dataProviderBean.aoRequests}" var="item">
    <f:facet name="noData">No messages are available.</f:facet>
    ...
    <rich:column>
        <f:facet name="header">Image data</f:facet>
        <rich:list value="#{item.imageContents}" var="content">
            <a4j:mediaOutput element="img" cacheable="false" session="false"
                createContent="#{imageBean.paint}" value="#{content}" />
        </rich:list>
    </rich:column>
</rich:dataTable>

2 个答案:

答案 0 :(得分:5)

如果将来有人会遇到同样的问题,这就是解决方案:

我放入content属性的value是一个保存图像二进制数据的对象。因为它是在URL中序列化的,所以长度太大而且不起作用。你必须传递一些id并在paint方法中获取对象。

Example

<rich:dataTable value="#{dataProviderBean.aoRequests}" var="item">
    <f:facet name="noData">No messages are available.</f:facet>
    ...
    <rich:column>
        <f:facet name="header">Image data</f:facet>
        <rich:list value="#{item.imageContents}" var="content">
            <a4j:mediaOutput element="img" cacheable="false" session="false"
                createContent="#{imageBean.paint}" value="#{content.id}" />
        </rich:list>
    </rich:column>
</rich:dataTable>

BEAN

public void paint(OutputStream os, Object data) throws IOException {
    String id = (String) data;
    BinaryContent content = (BinaryContent) getContentById(id);
    os.write(content.getContent());
}

答案 1 :(得分:-1)

ImageBean使用@SessionScoped或@ApplicationScope https://community.jboss.org/thread/168523